This is a valid RSS feed.
This feed is valid, but interoperability with the widest range of feed readers could be improved by implementing the following recommendations.
line 49, column 0: (2 occurrences) [help]
<div class="video-own" style="padding-top:5px;"><video style="width:99%;" po ...
line 49, column 0: (2 occurrences) [help]
<div class="video-own" style="padding-top:5px;"><video style="width:99%;" po ...
line 49, column 0: (2 occurrences) [help]
<div class="video-own" style="padding-top:5px;"><video style="width:99%;" po ...
line 49, column 0: (2 occurrences) [help]
<div class="video-own" style="padding-top:5px;"><video style="width:99%;" po ...
<?xml version="1.0" encoding="UTF-8"?><rss version="2.0"
xmlns:content="http://purl.org/rss/1.0/modules/content/"
xmlns:wfw="http://wellformedweb.org/CommentAPI/"
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:atom="http://www.w3.org/2005/Atom"
xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
>
<channel>
<title>Homepage nach Preis – Webseite erstellen lassen</title>
<atom:link href="https://homepage-nach-preis.de/feed/" rel="self" type="application/rss+xml" />
<link>https://homepage-nach-preis.de/</link>
<description>★ Responsive Webdesigner Homepage erstellen lassen, bereits ab 299 Euro professionelle Webseite. ✓ Google-Optimiert ✓ Mobil-Optimiert | Webdesign & Seo</description>
<lastBuildDate>Fri, 06 Sep 2024 16:40:50 +0000</lastBuildDate>
<language>de</language>
<sy:updatePeriod>
hourly </sy:updatePeriod>
<sy:updateFrequency>
1 </sy:updateFrequency>
<image>
<url>https://homepage-nach-preis.de/wp-content/uploads/2021/02/cropped-icon-150x150.png</url>
<title>Homepage nach Preis – Webseite erstellen lassen</title>
<link>https://homepage-nach-preis.de/</link>
<width>32</width>
<height>32</height>
</image>
<item>
<title>Simple Blockchain Beispiel mit Miner</title>
<link>https://homepage-nach-preis.de/2024/09/06/simple-blockchain-beispiel-mit-miner/</link>
<comments>https://homepage-nach-preis.de/2024/09/06/simple-blockchain-beispiel-mit-miner/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Fri, 06 Sep 2024 16:17:14 +0000</pubDate>
<category><![CDATA[Allgemein]]></category>
<category><![CDATA[Code]]></category>
<category><![CDATA[Beispiel]]></category>
<category><![CDATA[Blockchain]]></category>
<category><![CDATA[download]]></category>
<category><![CDATA[Miner]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8348</guid>
<description><![CDATA[<p>Wie funktioniert eine Kryptowährung bzw. eine Blockchain mit einem Proof of Work Mechanismus (Mining). Ihr Gerät unterstützt eine Wiedergabe des Videos nicht. Github: https://github.com/HNP-Christopher-Rohde/hnp-example-blockchain-with-miner Blockchain Die Blockchain in diesem System ist eine auf Blöcken basierende Kette, die kryptografisch gesichert ist. Jeder Block enthält folgende Informationen: Index: Die Position des Blocks in der Kette. Zeitstempel: Der Zeitpunkt, zu dem der Block erstellt wurde (in Unix-Zeit). Daten: Die im Block gespeicherten Informationen (in binärer Form). Vorheriger Hash: Der Hash des vorhergehenden Blocks, der die Verbindung zu diesem sicherstellt. Hash: Der eigene Hash des Blocks, der durch den Hashing-Algorithmus SHA-256 berechnet wird. Nonce: Eine Zahl, die während des Minings variiert wird, um den Hash zu finden, der den Anforderungen der Schwierigkeit entspricht. Die Blockchain wird mit einem Genesis-Block initialisiert. Jeder neue Block wird durch einen Mining-Prozess erstellt, der den Hash so anpasst, dass er den Schwierigkeitsanforderungen (Difficulty) entspricht, d. h. der Hash muss mit einer bestimmten Anzahl von Nullen beginnen. Die Schwierigkeit passt sich dynamisch an, basierend auf der Zeit, die für die Erstellung der letzten Blöcke benötigt wurde. Validität der Blockchain: Jeder Block in der Kette wird überprüft, um sicherzustellen, dass der Hash korrekt ist und der Hash des vorherigen Blocks mit....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/09/06/simple-blockchain-beispiel-mit-miner/">Simple Blockchain Beispiel mit Miner</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p><strong>Wie funktioniert eine Kryptowährung bzw. eine Blockchain mit einem Proof of Work Mechanismus (Mining). </strong></p>
<div class="video-own" style="padding-top:5px;"><video style="width:99%;" poster="https://homepage-nach-preis.de/wp-content/uploads/2024/09/blockchain.jpg" controls controlsList="nodownload" preload="none"><source src="https://homepage-nach-preis.de/wp-content/uploads/2024/09/2024-09-06-18-38-00.mp4" type="video/mp4"/>Ihr Gerät unterstützt eine Wiedergabe des Videos nicht.</video></div>
<p><strong>Github:</strong> <a href="https://github.com/HNP-Christopher-Rohde/hnp-example-blockchain-with-miner" target="_blank" rel="nofollow noopener">https://github.com/HNP-Christopher-Rohde/hnp-example-blockchain-with-miner</a></p>
<h4>Blockchain</h4>
<p>Die Blockchain in diesem System ist eine auf Blöcken basierende Kette, die kryptografisch gesichert ist. Jeder Block enthält folgende Informationen:</p>
<p> Index: Die Position des Blocks in der Kette.<br />
Zeitstempel: Der Zeitpunkt, zu dem der Block erstellt wurde (in Unix-Zeit).<br />
Daten: Die im Block gespeicherten Informationen (in binärer Form).<br />
Vorheriger Hash: Der Hash des vorhergehenden Blocks, der die Verbindung zu diesem sicherstellt.<br />
Hash: Der eigene Hash des Blocks, der durch den Hashing-Algorithmus SHA-256 berechnet wird.<br />
Nonce: Eine Zahl, die während des Minings variiert wird, um den Hash zu finden, der den Anforderungen der Schwierigkeit entspricht.</p>
<p>Die Blockchain wird mit einem Genesis-Block initialisiert. Jeder neue Block wird durch einen Mining-Prozess erstellt, der den Hash so anpasst, dass er den Schwierigkeitsanforderungen (Difficulty) entspricht, d. h. der Hash muss mit einer bestimmten Anzahl von Nullen beginnen. Die Schwierigkeit passt sich dynamisch an, basierend auf der Zeit, die für die Erstellung der letzten Blöcke benötigt wurde.</p>
<p><strong>Validität der Blockchain:</strong></p>
<p> Jeder Block in der Kette wird überprüft, um sicherzustellen, dass der Hash korrekt ist und der Hash des vorherigen Blocks mit dem gespeicherten previous_hash übereinstimmt.<br />
Es wird außerdem geprüft, ob der Block die Schwierigkeit (Difficulty) erfüllt, bevor er zur Kette hinzugefügt wird.</p>
<p>Die Blockchain speichert die Blöcke auf der Festplatte (z. B. in der Datei blockchain.json) und bietet APIs für den Empfang und das Senden neuer Blöcke zwischen Peers.</p>
<p><strong>Blockchain:</strong></p>
<pre>
use serde::{Serialize, Deserialize};
use std::collections::VecDeque;
use std::fs;
use sha2::Digest;
use hex;
use std::time::{SystemTime, UNIX_EPOCH};
use reqwest;
use warp::Filter;
use log::{info, error};
use std::env;
use std::sync::{Arc, Mutex};
#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct Block {
pub index: u64,
pub timestamp: u64,
pub data: Vec<u8>,
pub previous_hash: String,
pub hash: String,
pub nonce: u64,
}
impl Block {
pub fn new(index: u64, data: Vec<u8>, previous_hash: String) -> Self {
let timestamp = SystemTime::now().duration_since(UNIX_EPOCH).unwrap().as_secs();
let mut block = Block {
index,
timestamp,
data,
previous_hash,
hash: String::new(),
nonce: 0,
};
block.hash = block.calculate_hash();
info!("Created new block: {:?}", block);
block
}
pub fn calculate_hash(&self) -> String {
let mut hasher = sha2::Sha256::new();
hasher.update(format!("{}{}{}{}{}", self.index, self.timestamp, hex::encode(&self.data), self.previous_hash, self.nonce));
let result = hasher.finalize();
hex::encode(result)
}
}
#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct Blockchain {
pub chain: VecDeque<Block>,
pub difficulty: u32,
pub adjustment_interval: u64,
pub target_block_time: u64,
pub last_difficulty_update: u64,
}
impl Blockchain {
pub fn new(difficulty: u32, adjustment_interval: u64, target_block_time: u64) -> Self {
let mut chain = VecDeque::new();
chain.push_back(create_genesis_block());
info!("Blockchain initialized with genesis block");
Blockchain {
chain,
difficulty,
adjustment_interval,
target_block_time,
last_difficulty_update: SystemTime::now().duration_since(UNIX_EPOCH).unwrap().as_secs(),
}
}
pub fn add_block(&mut self, data: Vec<u8>) {
let previous_block = self.chain.back().unwrap();
let new_block = mine_block(previous_block, data, self.difficulty);
info!("Adding new block: {:?}", new_block);
self.chain.push_back(new_block);
// Update difficulty if needed
if (self.chain.len() as u64) % self.adjustment_interval == 0 {
self.update_difficulty_based_on_time();
}
if let Err(e) = self.save_to_file("blockchain.json") {
error!("Failed to save blockchain after adding block: {}", e);
}
}
pub fn is_valid(&self) -> bool {
for i in 1..self.chain.len() {
let current = &self.chain[i];
let previous = &self.chain[i - 1];
if current.hash != current.calculate_hash() {
error!("Block {} has invalid hash", current.index);
return false;
}
if current.previous_hash != previous.hash {
error!("Block {} has invalid previous hash", current.index);
return false;
}
if !meets_difficulty(&current.hash, self.difficulty) {
error!("Block {} does not meet difficulty", current.index);
return false;
}
}
true
}
pub fn save_to_file(&self, filename: &str) -> std::io::Result<()> {
let serialized = serde_json::to_string(self)
.expect("Serialization failed");
fs::write(filename, serialized).map_err(|e| {
error!("Failed to write blockchain to file: {}", e);
e
})?;
info!("Blockchain saved to file: {}", filename);
Ok(())
}
pub fn load_from_file(filename: &str) -> std::io::Result<Self> {
match fs::read_to_string(filename) {
Ok(data) if !data.is_empty() => {
match serde_json::from_str::<Blockchain>(&data) {
Ok(blockchain) => {
info!("Blockchain loaded from file: {}", filename);
Ok(blockchain)
}
Err(e) => {
info!("Failed to deserialize blockchain from file, creating a new one: {}", e);
let (difficulty, adjustment_interval, target_block_time) = load_config();
Ok(Blockchain::new(difficulty, adjustment_interval, target_block_time))
}
}
}
_ => {
info!("Blockchain file is empty or not found. Creating a new blockchain.");
let (difficulty, adjustment_interval, target_block_time) = load_config();
Ok(Blockchain::new(difficulty, adjustment_interval, target_block_time))
}
}
}
pub async fn broadcast_new_block(&self, block: &Block, peers: &[&str]) -> reqwest::Result<()> {
for peer in peers {
let url = format!("{}/new-block", peer);
info!("Broadcasting new block to peer: {}", url);
let result = reqwest::Client::new()
.post(&url)
.json(&block)
.send()
.await;
match result {
Ok(_) => info!("Successfully sent block to {}", url),
Err(e) => error!("Failed to send block to {}: {:?}", url, e),
}
}
Ok(())
}
</pre>
<pre>
pub fn add_block_from_request(&mut self, block: Block) -> bool {
let previous_block = self.chain.back().unwrap();
info!("Received block: {:?}", block);
info!("Last block in chain: {:?}", previous_block);
// Additional validation for the timestamp
if block.timestamp <= previous_block.timestamp {
error!("Block timestamp is not valid");
return false;
}
let is_valid = block.index == previous_block.index + 1
&& block.previous_hash == previous_block.hash
&& block.hash == block.calculate_hash()
&& meets_difficulty(&block.hash, self.difficulty);
if is_valid {
info!("Valid block received and added to chain");
self.chain.push_back(block);
if let Err(e) = self.save_to_file("blockchain.json") {
error!("Failed to save blockchain after adding block: {}", e);
}
} else {
error!("Invalid block received: \n\
Index: {} \n\
Previous Hash: {} \n\
Expected Previous Hash: {} \n\
Hash: {} \n\
Calculated Hash: {} \n\
Difficulty Met: {}",
block.index,
block.previous_hash,
previous_block.hash,
block.hash,
block.calculate_hash(),
meets_difficulty(&block.hash, self.difficulty));
}
is_valid
}
pub fn update_difficulty_based_on_time(&mut self) {
let length = self.chain.len() as u64;
info!("Chain length: {}", length);
if length >= self.adjustment_interval {
let interval_start_block = &self.chain[self.chain.len() - self.adjustment_interval as usize];
let interval_end_block = self.chain.back().unwrap();
let time_taken = interval_end_block.timestamp - interval_start_block.timestamp;
let expected_time = self.adjustment_interval * self.target_block_time;
info!("Time taken for the last {} blocks: {} seconds", self.adjustment_interval, time_taken);
info!("Expected time for the last {} blocks: {} seconds", self.adjustment_interval, expected_time);
if time_taken < expected_time / 2 {
self.difficulty += 1;
info!("Difficulty increased to {}", self.difficulty);
} else if time_taken > expected_time * 2 {
if self.difficulty > 1 {
self.difficulty -= 1;
info!("Difficulty decreased to {}", self.difficulty);
}
} else {
info!("Difficulty remains at {}", self.difficulty);
}
// Update the last difficulty update timestamp
self.last_difficulty_update = SystemTime::now().duration_since(UNIX_EPOCH).unwrap().as_secs();
} else {
info!("Not enough blocks to adjust difficulty.");
}
}
pub fn update_difficulty(&mut self, new_difficulty: u32) {
self.difficulty = new_difficulty;
info!("Difficulty updated to {}", new_difficulty);
if let Err(e) = self.save_to_file("blockchain.json") {
error!("Failed to save blockchain after updating difficulty: {}", e);
}
}
}
pub fn create_genesis_block() -> Block {
Block::new(0, "Genesis Block".as_bytes().to_vec(), "0".to_string())
}
fn meets_difficulty(hash: &str, difficulty: u32) -> bool {
let target = vec![0u8; difficulty as usize];
let hash_bytes = hex::decode(hash).expect("Hex decode failed");
hash_bytes.len() >= target.len() && hash_bytes.starts_with(&target)
}
fn mine_block(previous_block: &Block, data: Vec<u8>, difficulty: u32) -> Block {
let mut new_block = Block::new(previous_block.index + 1, data.clone(), previous_block.hash.clone());
let mut attempt = 0;
while !meets_difficulty(&new_block.hash, difficulty) {
new_block.nonce += 1;
new_block.hash = new_block.calculate_hash();
attempt += 1;
if attempt % 100 == 0 {
println!("Attempt {}: Trying hash: {}", attempt, new_block.hash);
}
}
new_block
}
fn load_config() -> (u32, u64, u64) {
use serde::Deserialize;
#[derive(Deserialize)]
struct Config {
initial_difficulty: u32,
adjustment_interval: u64,
target_block_time: u64,
}
let data = fs::read_to_string("config.json").expect("Unable to read config file");
let config: Config = serde_json::from_str(&data).expect("Unable to parse config file");
(config.initial_difficulty, config.adjustment_interval, config.target_block_time)
}
#[tokio::main]
async fn main() {
env::set_var("RUST_LOG", "info");
env_logger::init();
let (initial_difficulty, adjustment_interval, target_block_time) = load_config();
let blockchain = Arc::new(Mutex::new(
Blockchain::load_from_file("blockchain.json").unwrap_or_else(|_| Blockchain::new(initial_difficulty, adjustment_interval, target_block_time))
));
let blockchain_filter = warp::any().map(move || blockchain.clone());
let new_block = warp::post()
.and(warp::path("new-block"))
.and(warp::body::json())
.and(blockchain_filter.clone())
.map(|block: Block, blockchain: Arc<Mutex<Blockchain>>| {
let mut blockchain = blockchain.lock().unwrap();
let response = if blockchain.add_block_from_request(block) {
"Block added successfully"
} else {
"Invalid block"
};
response
});
let difficulty = warp::get()
.and(warp::path("difficulty"))
.map(move || format!("Difficulty: {}", initial_difficulty));
let set_difficulty = warp::post()
.and(warp::path("set-difficulty"))
.and(warp::body::json())
.and(blockchain_filter.clone())
.map(|_new_difficulty: u32, _blockchain: Arc<Mutex<Blockchain>>| {
// Ignoring difficulty change here, as it's handled externally
format!("Difficulty updated to {}", _new_difficulty)
});
let last_block = warp::get()
.and(warp::path("last-block"))
.and(blockchain_filter.clone())
.map(|blockchain: Arc<Mutex<Blockchain>>| {
let blockchain = blockchain.lock().unwrap();
let last_block = blockchain.chain.back().cloned().unwrap_or_else(|| create_genesis_block());
warp::reply::json(&last_block)
});
let routes = new_block.or(difficulty).or(set_difficulty).or(last_block);
info!("Starting server at http://127.0.0.1:8000");
warp::serve(routes).run(([127, 0, 0, 1], 8000)).await;
}
</pre>
<h4>Miner</h4>
<p>Der Miner ist für die Erstellung neuer Blöcke in der Blockchain verantwortlich. Er arbeitet nach einem Proof-of-Work-Mechanismus, bei dem der Miner eine nonce-Nummer anpasst, bis ein gültiger Hash gefunden wird, der den Schwierigkeitsanforderungen entspricht.</p>
<p><strong>Ablauf des Mining-Prozesses:</strong></p>
<p> Der Miner fragt den letzten Block der Blockchain von einem Server ab.<br />
Der Miner fragt die aktuelle Schwierigkeit vom Server ab.<br />
Ein neuer Block wird erstellt, indem die Daten des vorherigen Blocks verwendet werden, sowie neue Transaktionsdaten.<br />
Der Miner berechnet den Hash des neuen Blocks durch Anpassung der nonce, bis der Hash die Schwierigkeit erfüllt (d. h., der Hash beginnt mit einer bestimmten Anzahl von Nullen).<br />
Sobald ein gültiger Block gefunden wurde, wird er an den Server gesendet, der ihn zur Blockchain hinzufügt.</p>
<p>Der Mining-Prozess läuft in einem Loop, sodass kontinuierlich nach neuen Blöcken gesucht wird, die der Blockchain hinzugefügt werden können.</p>
<pre>
use serde::{Serialize, Deserialize};
use sha2::{Sha256, Digest};
use std::time::{SystemTime, UNIX_EPOCH};
use reqwest;
use hex;
use anyhow::{Result, Context};
use tokio::task;
#[derive(Debug, Serialize, Deserialize, Clone)]
pub struct Block {
pub index: u64,
pub timestamp: u64,
pub data: Vec<u8>,
pub previous_hash: String,
pub hash: String,
pub nonce: u64,
}
impl Block {
pub fn new(index: u64, data: Vec<u8>, previous_hash: String) -> Self {
let timestamp = SystemTime::now().duration_since(UNIX_EPOCH).unwrap().as_secs();
let mut block = Block {
index,
timestamp,
data,
previous_hash,
hash: String::new(),
nonce: 0,
};
block.hash = block.calculate_hash();
block
}
pub fn calculate_hash(&self) -> String {
let mut hasher = Sha256::new();
hasher.update(format!("{}{}{}{}{}", self.index, self.timestamp, hex::encode(&self.data), self.previous_hash, self.nonce));
let result = hasher.finalize();
hex::encode(result)
}
}
fn meets_difficulty(hash: &str, difficulty: u32) -> bool {
let target = vec![0u8; difficulty as usize];
let hash_bytes = hex::decode(hash).expect("Hex decode failed");
hash_bytes.starts_with(&target)
}
async fn mine_block(previous_block: &Block, data: Vec<u8>, difficulty: u32) -> Block {
let mut new_block = Block::new(previous_block.index + 1, data.clone(), previous_block.hash.clone());
// Parallel mining using multiple threads
let mining_task = task::spawn_blocking(move || {
let mut attempt = 0;
while !meets_difficulty(&new_block.hash, difficulty) {
new_block.nonce += 1;
new_block.hash = new_block.calculate_hash();
attempt += 1;
if attempt % 100 == 0 {
println!("Attempt {}: Trying hash: {}", attempt, new_block.hash);
}
}
new_block
});
mining_task.await.unwrap()
}
async fn get_last_block_from_server() -> Result<Block> {
let client = reqwest::Client::new();
let url = "http://localhost:8000/last-block";
let res = client.get(url)
.send()
.await
.context("Failed to send request to get last block")?;
let last_block: Block = res.json().await
.context("Failed to parse last block")?;
Ok(last_block)
}
async fn send_block_to_server(block: &Block) -> Result<()> {
let client = reqwest::Client::new();
let url = "http://localhost:8000/new-block";
println!("Sending block: {:?}", block);
let res = client.post(url)
.json(block)
.send()
.await
.context("Failed to send request to post new block")?;
let status = res.status();
let body = res.text().await
.context("Failed to read response text")?;
if status.is_success() {
println!("Block successfully sent to server.");
} else {
println!("Failed to send block to server: {} - {}", status, body);
}
Ok(())
}
</pre>
<pre>
async fn get_difficulty_from_server() -> Result<u32> {
let client = reqwest::Client::new();
let url = "http://localhost:8000/difficulty";
let res = client.get(url)
.send()
.await
.context("Failed to send request to get difficulty")?;
let difficulty_str = res.text().await
.context("Failed to read difficulty response")?;
let difficulty = difficulty_str.trim_start_matches("Difficulty: ")
.parse::<u32>()
.context("Failed to parse difficulty")?;
Ok(difficulty)
}
async fn display_difficulty() -> Result<()> {
let difficulty = get_difficulty_from_server().await
.context("Error retrieving difficulty from server")?;
println!("Current Difficulty: {}", difficulty);
Ok(())
}
#[tokio::main]
async fn main() -> Result<()> {
loop {
// Anzeige der aktuellen Schwierigkeit
display_difficulty().await
.context("Error displaying difficulty")?;
// Hol die Schwierigkeit vom Server
let difficulty = get_difficulty_from_server().await
.context("Error retrieving difficulty from server")?;
// Hol den letzten Block vom Server
let previous_block = get_last_block_from_server().await
.context("Error retrieving last block from server")?;
let data = b"Block data".to_vec();
let new_block = mine_block(&previous_block, data, difficulty).await;
send_block_to_server(&new_block).await
.context("Error sending block to server")?;
// Warte eine gewisse Zeit, bevor der nächste Block erstellt wird
tokio::time::sleep(tokio::time::Duration::from_secs(0)).await; // Wartezeit erhöht
}
}
</pre>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/09/06/simple-blockchain-beispiel-mit-miner/">Simple Blockchain Beispiel mit Miner</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/09/06/simple-blockchain-beispiel-mit-miner/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
<enclosure url="https://homepage-nach-preis.de/wp-content/uploads/2024/09/2024-09-06-18-38-00.mp4" length="41740699" type="video/mp4" />
</item>
<item>
<title>WooCommerce für Windows – Software von HNP</title>
<link>https://homepage-nach-preis.de/2024/05/28/woocommerce-fuer-windows-software-von-hnp/</link>
<comments>https://homepage-nach-preis.de/2024/05/28/woocommerce-fuer-windows-software-von-hnp/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Tue, 28 May 2024 19:08:50 +0000</pubDate>
<category><![CDATA[Homepage]]></category>
<category><![CDATA[Onlineshop]]></category>
<category><![CDATA[Webdesign]]></category>
<category><![CDATA[App]]></category>
<category><![CDATA[Client]]></category>
<category><![CDATA[software]]></category>
<category><![CDATA[Verbinundung]]></category>
<category><![CDATA[Windows]]></category>
<category><![CDATA[Woocommerce]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8298</guid>
<description><![CDATA[<p>Entfesseln Sie das volle Potenzial Ihres WooCommerce-Shops mit unserer leistungsstarken Windows-Software Ihr Gerät unterstützt eine Wiedergabe des Videos nicht. Wenn Sie einen WooCommerce-Shop betreiben, wissen Sie, wie wichtig effizientes und zuverlässiges Management ist. Unsere innovative Windows-Software wurde speziell entwickelt, um Ihre Verwaltung zu vereinfachen und Ihre Produktivität zu steigern. Mit einer Vielzahl von Funktionen, die speziell auf die Bedürfnisse von WooCommerce-Shop-Betreibern zugeschnitten sind, bietet unsere Software alles, was Sie benötigen, um Ihren Shop nahtlos zu verwalten.   Bestellungen verwalten leicht gemacht Unsere Software bietet eine umfassende Übersicht über alle Bestellungen in Ihrem Shop. Sie können Bestellungen nach Kundenname, Order-ID oder anderen Daten filtern und sofort aktualisieren. Mit dem intelligenten Stornierungssystem können Sie Bestellungen und einzelne Produkte sicher und effizient stornieren. Dank der automatischen Aktualisierungsfunktion bleiben Ihre Daten immer auf dem neuesten Stand. Weitere Highlights umfassen: Manuelle und automatische Rückerstattungen Bestellnotizen einsehen und E-Mails an Kunden senden Druck- und Kopierfunktionen für Bestellungen   Produktmanagement auf höchstem Niveau Verwalten Sie alle Ihre Produkte, von einfachen bis hin zu variablen Produkten, direkt über unsere Software. Bearbeiten Sie Preise, Namen, Lagerbestände und SEO-Daten mühelos. Unsere Software unterstützt Sie dabei, Produktbilder hochzuladen und zu ändern und bietet eine eigene Browserfunktion zum Ansehen Ihrer Produkte. Durch....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/05/28/woocommerce-fuer-windows-software-von-hnp/">WooCommerce für Windows – Software von HNP</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<h3>Entfesseln Sie das volle Potenzial Ihres WooCommerce-Shops mit unserer leistungsstarken Windows-Software</h3>
<div class="video-own" style="padding-top:5px;"><video style="width:99%;" poster="https://homepage-nach-preis.de/wp-content/uploads/2024/05/poster-hnp-win-woo.jpg" controls controlsList="nodownload" preload="none"><source src="https://homepage-nach-preis.de/wp-content/uploads/2024/06/HNP-Win-Manager-fuer-WooCommerce-WooCommerce-fuer-Windows-Software.mp4" type="video/mp4"/>Ihr Gerät unterstützt eine Wiedergabe des Videos nicht.</video></div>
<p>Wenn Sie einen WooCommerce-Shop betreiben, wissen Sie, wie wichtig effizientes und zuverlässiges Management ist. Unsere innovative Windows-Software wurde speziell entwickelt, um Ihre Verwaltung zu vereinfachen und Ihre Produktivität zu steigern. Mit einer Vielzahl von Funktionen, die speziell auf die Bedürfnisse von WooCommerce-Shop-Betreibern zugeschnitten sind, bietet unsere Software alles, was Sie benötigen, um Ihren Shop nahtlos zu verwalten.</p>
<p> </p>
<h4><strong>Bestellungen verwalten leicht gemacht</strong></h4>
<p>Unsere Software bietet eine umfassende Übersicht über alle Bestellungen in Ihrem Shop. Sie können Bestellungen nach Kundenname, Order-ID oder anderen Daten filtern und sofort aktualisieren. Mit dem intelligenten Stornierungssystem können Sie Bestellungen und einzelne Produkte sicher und effizient stornieren. Dank der automatischen Aktualisierungsfunktion bleiben Ihre Daten immer auf dem neuesten Stand. Weitere Highlights umfassen:</p>
<ul>
<li>Manuelle und automatische Rückerstattungen</li>
<li>Bestellnotizen einsehen und E-Mails an Kunden senden</li>
<li>Druck- und Kopierfunktionen für Bestellungen</li>
</ul>
<p> </p>
<h4><strong>Produktmanagement auf höchstem Niveau</strong></h4>
<p>Verwalten Sie alle Ihre Produkte, von einfachen bis hin zu variablen Produkten, direkt über unsere Software. Bearbeiten Sie Preise, Namen, Lagerbestände und SEO-Daten mühelos. Unsere Software unterstützt Sie dabei, Produktbilder hochzuladen und zu ändern und bietet eine eigene Browserfunktion zum Ansehen Ihrer Produkte. Durch die Filter- und Aktualisierungsfunktionen behalten Sie stets den Überblick und können sofort auf Änderungen reagieren.</p>
<p> </p>
<h4><strong>Kunden- und Benutzerverwaltung optimiert</strong></h4>
<p>Die Verwaltung von Nutzern und Kunden war noch nie so einfach. Mit unserer Software können Sie alle Benutzerinformationen einsehen und bearbeiten, einschließlich Name, Rolle, E-Mail und Rechnungsdaten. Sicherheitsfunktionen verhindern unbefugte Änderungen an Administratoren. Versenden Sie Passwortrücksetzungs-E-Mails und individuelle Nachrichten direkt aus der Software.</p>
<p> </p>
<h4><strong>Effizientes Gutschein-Management</strong></h4>
<p>Unsere Software ermöglicht es Ihnen, Gutscheine zu verwalten, zu bearbeiten und zu erstellen. Filtern Sie Gutscheine nach Code, E-Mail oder anderen Daten und aktualisieren Sie sie automatisch. Sie können Gutscheine löschen und neue mit denselben Daten erstellen, was Ihre Marketingstrategien erheblich vereinfacht.</p>
<p> </p>
<h4><strong>Bewertungen im Griff</strong></h4>
<p>Behalten Sie alle Bewertungen Ihrer Produkte im Blick. Filtern Sie Bewertungen nach Produkt, E-Mail oder anderen Daten und bearbeiten Sie sie direkt in der Software. Mit der automatischen Aktualisierungsfunktion sind Ihre Daten stets aktuell, und Sie können unerwünschte Bewertungen einfach löschen.</p>
<p> </p>
<h4><strong>Umfassende Statistikfunktionen</strong></h4>
<p>Verfolgen Sie Ihre Verkaufsleistung mit unserem Sales over Time-Diagramm, das die Verkäufe der letzten 12 Monate anzeigt. Drucken Sie Diagramme aus und behalten Sie den Überblick über Ihre Geschäftsentwicklung.</p>
<p> </p>
<h4><strong>Leistungsstarke Tools für mehr Effizienz</strong></h4>
<p>Unsere Software bietet eine Reihe von Tools, die speziell entwickelt wurden, um Ihre Arbeit zu erleichtern:</p>
<ul>
<li><strong>CSV Produkt Import:</strong> Erstellen Sie Produkte durch CSV-Dateien, validieren Sie Daten vor dem Upload und unterstützen Sie unbegrenzte Produktmengen.</li>
<li><strong>Massen-Preis-Veränderung:</strong> Passen Sie Preise von allen Produkten im Shop an, entweder in Euro oder Prozent.</li>
<li><strong>Massen-Email-Funktionen:</strong> Versenden Sie E-Mails an alle Nutzer oder Kunden, ähnlich wie bei einer Newsletter-Funktion.</li>
<li><strong>Shop Nachrichten:</strong> Platzieren und aktualisieren Sie individuelle Nachrichten auf Ihrer Webseite mit Shortcodes.</li>
<li><strong>Zahlungseinstellungen:</strong> Aktivieren oder deaktivieren Sie Zahlungsmöglichkeiten mit einem Klick.</li>
<li><strong>Update Plugins und WordPress:</strong> Aktualisieren Sie Plugins und die WordPress-Version direkt über die Software.</li>
</ul>
<p> </p>
<h4><strong>Warum unsere Software?</strong></h4>
<p>Unsere Software ist mehr als nur ein Verwaltungswerkzeug. Sie ist Ihr Partner für ein effizientes und erfolgreiches WooCommerce-Management. Mit einer benutzerfreundlichen Oberfläche und robusten Funktionen optimieren Sie Ihre Geschäftsprozesse und sparen wertvolle Zeit. Machen Sie sich das Leben leichter und steigern Sie Ihre Produktivität – mit unserer maßgeschneiderten Lösung für WooCommerce.</p>
<p>Lassen Sie sich diese Chance nicht entgehen! Testen Sie unsere Software und erleben Sie, wie einfach und effizient das Management Ihres WooCommerce-Shops sein kann. Kontaktieren Sie uns noch heute und erfahren Sie mehr darüber, wie unsere Software Ihnen helfen kann, Ihre Geschäftsziele zu erreichen.<br />
</p>
<p><strong>Kostenloser Demo Download, mehr Informationen und Lizenzschlüssel für Vollversion kaufen:</strong><br />
<a href="https://shop.homepage-nach-preis.de/produkt/hnp-windows-manager-fuer-woocommerce/" target="_blank" rel="noopener nofollow">https://shop.homepage-nach-preis.de/produkt/hnp-windows-manager-fuer-woocommerce/</a></p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/05/28/woocommerce-fuer-windows-software-von-hnp/">WooCommerce für Windows – Software von HNP</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/05/28/woocommerce-fuer-windows-software-von-hnp/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
<enclosure url="https://homepage-nach-preis.de/wp-content/uploads/2024/06/HNP-Win-Manager-fuer-WooCommerce-WooCommerce-fuer-Windows-Software.mp4" length="38556131" type="video/mp4" />
</item>
<item>
<title>WordPress Rest API Schnittstelle mit Firewall</title>
<link>https://homepage-nach-preis.de/2024/05/22/wordpress-rest-api-schnittstelle-mit-firewall/</link>
<comments>https://homepage-nach-preis.de/2024/05/22/wordpress-rest-api-schnittstelle-mit-firewall/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Wed, 22 May 2024 12:41:18 +0000</pubDate>
<category><![CDATA[Allgemein]]></category>
<category><![CDATA[Homepage]]></category>
<category><![CDATA[Webdesign]]></category>
<category><![CDATA[Wordpress Code]]></category>
<category><![CDATA[API]]></category>
<category><![CDATA[Firewall]]></category>
<category><![CDATA[Schnitstelle]]></category>
<category><![CDATA[wordpress]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8247</guid>
<description><![CDATA[<p>Registrierung der benutzerdefinierten REST-Route Die Funktion zur Registrierung der REST-API-Route wird verwendet, um einen neuen Endpunkt in WordPress hinzuzufügen. Dieser Endpunkt ermöglicht es, externe Anfragen an WordPress zu senden und eine Antwort zu erhalten. Schritte der Registrierung: Hook zur Initialisierung der REST-API: Mit add_action('rest_api_init', function () { … }); wird eine anonyme Funktion registriert, die während der Initialisierung der REST-API aufgerufen wird. Definition der Route: Innerhalb dieser anonymen Funktion wird register_rest_route aufgerufen, um die Route zu definieren. Namespace: 'hnp_api_firewall/v1' legt den Namespace fest, der als Versionierung der API dient. Route: '/api' ist der spezifische Endpunkt innerhalb des Namespace. Optionen: Ein Array von Optionen, darunter: Methode: 'methods' => 'POST' spezifiziert, dass die Route nur POST-Anfragen akzeptiert. Callback: 'callback' => 'hnp_api_firewall_callback' gibt die Funktion an, die aufgerufen wird, wenn die Route erreicht wird. Berechtigung: 'permission_callback' => 'hnp_api_firewall_combined_permissions' bestimmt die Funktion, die die Berechtigungen für den Zugriff auf die Route überprüft. Kombinierte Berechtigungs- und Blockierungslogik Die Funktion hnp_api_firewall_combined_permissions dient dazu, die Berechtigungen und Blockierungslogik zu kombinieren. Sie wird aufgerufen, bevor die Haupt-Callback-Funktion ausgeführt wird, um sicherzustellen, dass nur berechtigte Anfragen zugelassen werden. Schritte der Berechtigungsprüfung: IP-Überprüfung: Die IP-Adresse des Anfragenden wird überprüft, um festzustellen, ob sie blockiert ist. Wenn die IP-Adresse blockiert ist....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/05/22/wordpress-rest-api-schnittstelle-mit-firewall/">WordPress Rest API Schnittstelle mit Firewall</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p><strong><br />
Registrierung der benutzerdefinierten REST-Route</strong></p>
<p>Die Funktion zur Registrierung der REST-API-Route wird verwendet, um einen neuen Endpunkt in WordPress hinzuzufügen. Dieser Endpunkt ermöglicht es, externe Anfragen an WordPress zu senden und eine Antwort zu erhalten.</p>
<p><strong>Schritte der Registrierung:</strong></p>
<p> Hook zur Initialisierung der REST-API: Mit add_action('rest_api_init', function () { … }); wird eine anonyme Funktion registriert, die während der Initialisierung der REST-API aufgerufen wird.<br />
Definition der Route: Innerhalb dieser anonymen Funktion wird register_rest_route aufgerufen, um die Route zu definieren.<br />
Namespace: 'hnp_api_firewall/v1' legt den Namespace fest, der als Versionierung der API dient.<br />
Route: '/api' ist der spezifische Endpunkt innerhalb des Namespace.<br />
Optionen: Ein Array von Optionen, darunter:<br />
Methode: 'methods' => 'POST' spezifiziert, dass die Route nur POST-Anfragen akzeptiert.<br />
Callback: 'callback' => 'hnp_api_firewall_callback' gibt die Funktion an, die aufgerufen wird, wenn die Route erreicht wird.<br />
Berechtigung: 'permission_callback' => 'hnp_api_firewall_combined_permissions' bestimmt die Funktion, die die Berechtigungen für den Zugriff auf die Route überprüft.</p>
<p><strong>Kombinierte Berechtigungs- und Blockierungslogik</strong></p>
<p>Die Funktion hnp_api_firewall_combined_permissions dient dazu, die Berechtigungen und Blockierungslogik zu kombinieren. Sie wird aufgerufen, bevor die Haupt-Callback-Funktion ausgeführt wird, um sicherzustellen, dass nur berechtigte Anfragen zugelassen werden.</p>
<p><strong>Schritte der Berechtigungsprüfung:</strong></p>
<p> IP-Überprüfung: Die IP-Adresse des Anfragenden wird überprüft, um festzustellen, ob sie blockiert ist.<br />
Wenn die IP-Adresse blockiert ist und die Blockierungsdauer noch nicht abgelaufen ist, wird der Zugriff verweigert.<br />
Wenn die Blockierungsdauer abgelaufen ist, wird die IP-Adresse entsperrt und die Blockierungsinformationen werden zurückgesetzt.</p>
<p> Überprüfung der API-Benutzer und -Geheimnisse: Die Kopfzeilen der Anfrage werden auf gültige API-Benutzer und -Geheimnisse überprüft.<br />
Wenn die Anmeldedaten korrekt sind, wird der Zähler für gültige Versuche erhöht.<br />
Wenn die Anmeldedaten falsch sind, wird der Zähler für ungültige Versuche erhöht.<br />
Wenn die Anzahl ungültiger Versuche einen bestimmten Schwellenwert überschreitet (z.B. 50), wird die IP-Adresse blockiert.</p>
<p> Versuchsverfolgung: Die Anzahl der erfolgreichen und fehlgeschlagenen Anmeldeversuche wird verfolgt, um die Blockierungslogik zu unterstützen.</p>
<p><strong>Rückgabewert</strong></p>
<p> Erfolgreiche Berechtigung: Wenn die Berechtigung erfolgreich ist, gibt die Funktion true zurück, wodurch die Haupt-Callback-Funktion hnp_api_firewall_callback aufgerufen wird.<br />
Fehlgeschlagene Berechtigung: Wenn die Berechtigung fehlschlägt, wird ein Fehler zurückgegeben und die Haupt-Callback-Funktion wird nicht ausgeführt.</p>
<p><strong>Haupt-Callback-Funktion</strong></p>
<p>Die Haupt-Callback-Funktion hnp_api_firewall_callback wird aufgerufen, wenn die Berechtigung erfolgreich ist und die Route erreicht wird. Sie gibt eine JSON-Antwort mit dem Dateninhalt zurück, der in diesem Fall ein einfaches Beispiel mit {"testdata": "test"} ist.</p>
<pre>
// Register the custom REST route
add_action('rest_api_init', function () {
register_rest_route('hnp_api_firewall/v1', '/api', array(
'methods' => 'POST',
'callback' => 'hnp_api_firewall_callback',
'permission_callback' => 'hnp_api_firewall_combined_permissions',
));
});
// Combined function to handle permissions and blocking logic
function hnp_api_firewall_combined_permissions(WP_REST_Request $request) {
$ip_address = sanitize_text_field($_SERVER['REMOTE_ADDR']);
$blocked_ips = get_option('hnp_blocked_ips', array());
// Check if IP is blocked
if (isset($blocked_ips[$ip_address])) {
$block_info = $blocked_ips[$ip_address];
$block_time = $block_info['block_time'];
$block_duration = $block_info['block_duration'];
$current_time = current_time('timestamp');
// If current time is less than block time + block duration, deny access
if ($current_time < ($block_time + $block_duration)) {
return new WP_Error('blocked_ip', 'Your IP is temporarily blocked due to too many attempts.', array('status' => 403));
} else {
// Unblock IP and reset attempts after block duration
unset($blocked_ips[$ip_address]);
update_option('hnp_blocked_ips', $blocked_ips);
}
}
// Check API user and secret
$api_user = $request->get_header('APIUser');
$api_secret = $request->get_header('APISecret');
$valid_api_user = '4GI53seaRLu!FK9XEiAk323U6M!f2bT7Sda28ZqsaegQCn0!Y121Y1L';
$valid_api_secret = '091572EddV!YcTKGR3Q13a!CM6TN!UWbPqFRdwa1XpP!1g8o32aaJD4';
// Tracking attempts
$attempts = get_option('hnp_attempts', array());
if (!isset($attempts[$ip_address])) {
$attempts[$ip_address] = array(
'valid_count' => 0,
'invalid_count' => 0,
'invalid_license_count' => 0,
'first_attempt_time' => current_time('timestamp')
);
}
$permission_granted = null !== $api_user && $api_user === $valid_api_user && null !== $api_secret && $api_secret === $valid_api_secret;
if ($permission_granted) {
$attempts[$ip_address]['valid_count']++;
} else {
$attempts[$ip_address]['invalid_count']++;
// Block IP if invalid attempts exceed threshold (e.g., 50)
if ($attempts[$ip_address]['invalid_count'] >= 50) {
$blocked_ips[$ip_address] = array('block_time' => current_time('timestamp'), 'block_duration' => 12 * HOUR_IN_SECONDS);
update_option('hnp_blocked_ips', $blocked_ips);
return new WP_Error('blocked_ip', 'Your IP is temporarily blocked due to too many invalid attempts for API Secret/Username.', array('status' => 403));
}
update_option('hnp_attempts', $attempts);
return new WP_Error('invalid_credentials', 'Invalid API Secret key or password.', array('status' => 403));
}
// Reset invalid attempts on successful authentication
if (isset($attempts[$ip_address])) {
unset($attempts[$ip_address]['invalid_count']);
update_option('hnp_attempts', $attempts);
}
return true;
}
function hnp_api_firewall_callback() {
return new WP_REST_Response(array(
'testdata' => 'test'
), 200);
}
</pre>
<p><strong>cUrl Anfrage zum Testen:</strong></p>
<pre>
curl -X POST https://yourdomain.com/wp-json/hnp_api_firewall/v1/api \
-H "APIUser: 4GI53seaRLu!FK9XEiAk323U6M!f2bT7Sda28ZqsaegQCn0!Y121Y1L" \
-H "APISecret: 091572EddV!YcTKGR3Q13a!CM6TN!UWbPqFRdwa1XpP!1g8o32aaJD4"
</pre>
<p><strong>PHP Anfrage zum Testen:</strong></p>
<pre>
<?php
function call_hnp_api_firewall() {
$url = 'https://yourdomain.com/wp-json/hnp_api_firewall/v1/api';
$args = array(
'headers' => array(
'APIUser' => '4GI53seaRLu!FK9XEiAk323U6M!f2bT7Sda28ZqsaegQCn0!Y121Y1L',
'APISecret' => '091572EddV!YcTKGR3Q13a!CM6TN!UWbPqFRdwa1XpP!1g8o32aaJD4'
),
'body' => array(
// Any additional data you want to send in the body
)
);
$response = wp_remote_post($url, $args);
if (is_wp_error($response)) {
$error_message = $response->get_error_message();
echo "Something went wrong: $error_message";
} else {
$response_body = wp_remote_retrieve_body($response);
echo 'Response:<br>';
echo '<pre>';
print_r(json_decode($response_body, true));
echo '</pre>';
}
}
// Call the function
call_hnp_api_firewall();
?>
</pre>
<p><strong>C# Anfrage zum Testen:</strong></p>
<pre>
using System;
using System.Net.Http;
using System.Net.Http.Headers;
using System.Threading.Tasks;
class Program
{
private static async Task CallHnpApiFirewallAsync()
{
var url = "https://yourdomain.com/wp-json/hnp_api_firewall/v1/api";
using (var client = new HttpClient())
{
// Set the APIUser and APISecret headers
client.DefaultRequestHeaders.Add("APIUser", "4GI53seaRLu!FK9XEiAk323U6M!f2bT7Sda28ZqsaegQCn0!Y121Y1L");
client.DefaultRequestHeaders.Add("APISecret", "091572EddV!YcTKGR3Q13a!CM6TN!UWbPqFRdwa1XpP!1g8o32aaJD4");
// Optionally set the content of the request (if needed)
var content = new StringContent("", System.Text.Encoding.UTF8, "application/json");
try
{
var response = await client.PostAsync(url, content);
if (response.IsSuccessStatusCode)
{
var responseBody = await response.Content.ReadAsStringAsync();
Console.WriteLine("Response:");
Console.WriteLine(responseBody);
}
else
{
Console.WriteLine($"Error: {response.StatusCode}");
}
}
catch (Exception ex)
{
Console.WriteLine($"Exception: {ex.Message}");
}
}
}
static void Main(string[] args)
{
Task.Run(() => CallHnpApiFirewallAsync()).GetAwaiter().GetResult();
}
}
</pre>
<p><strong>Sicherheit:</strong></p>
<p>Anzahl der möglichen Kombinationen bei BrutForceAttacken</p>
<p>Einzelne Schlüssel:</p>
<p>Für einen einzelnen Schlüssel mit 50 Zeichen und 94 möglichen Zeichen pro Position ergibt sich:<br />
945094 hoch50<br />
Zwei Schlüssel kombiniert</p>
<p>Da beide Schlüssel unabhängig voneinander betrachtet werden, multiplizieren wir die Anzahl der möglichen Kombinationen beider Schlüssel:</p>
<p>(94 hoch50)×(94 hoch50)(94 hoch50)×(94 hoch50)</p>
<p><strong>Dies entspricht:</strong><br />
9410094 hoch100</p>
<p><strong>Zeit für einen Brute-Force-Angriff</strong></p>
<p>Angenommen, ein Computer kann 1 Milliarde (1.000.000.000) Kombinationen pro Sekunde testen:</p>
<p> Anzahl der Kombinationen:<br />
Die Anzahl der Kombinationen für einen Schlüssel: 945094 hoch50 (eine extrem große Zahl)<br />
Die Anzahl der Kombinationen für beide Schlüssel: 9410094 hoch100 (noch viel größer)</p>
<p><strong> Zeit für Brute-Force:</strong><br />
Selbst wenn ein Computer 1 Milliarde Kombinationen pro Sekunde testen könnte, würde das Testen aller Kombinationen von zwei Schlüsseln extrem lange dauern.<br />
Zum Vergleich:<br />
Eine Milliarde Sekunden sind etwa 31,7 Jahre.</p>
<p><strong> Die Anzahl der Kombinationen für 9410094 hoch100 ist so groß, dass selbst mit extrem schneller Hardware Billionen von Jahren benötigt würden, um alle Kombinationen zu testen.</strong></p>
<p><strong>Durch die Rate Limitierung der Firewall wird die Zeit auf Milliarden von Jahren erhöht, zudem sind DDOS oder ähnliche Hacking-Angriffe nicht möglich. Die Schnittstelle wird somit zusätzlich geschützt. </strong></p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/05/22/wordpress-rest-api-schnittstelle-mit-firewall/">WordPress Rest API Schnittstelle mit Firewall</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/05/22/wordpress-rest-api-schnittstelle-mit-firewall/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
</item>
<item>
<title>HNP Win Data Handler – Datenaustausch zwischen WordPress & Windows</title>
<link>https://homepage-nach-preis.de/2024/04/27/hnp-win-data-handler-datenaustausch-zwischen-wordpress-windows/</link>
<comments>https://homepage-nach-preis.de/2024/04/27/hnp-win-data-handler-datenaustausch-zwischen-wordpress-windows/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Sat, 27 Apr 2024 13:27:14 +0000</pubDate>
<category><![CDATA[Homepage]]></category>
<category><![CDATA[Webdesign]]></category>
<category><![CDATA[Wordpress Code]]></category>
<category><![CDATA[API]]></category>
<category><![CDATA[Code]]></category>
<category><![CDATA[download]]></category>
<category><![CDATA[HNP Win Data Handler]]></category>
<category><![CDATA[Rest]]></category>
<category><![CDATA[software]]></category>
<category><![CDATA[Verbindung]]></category>
<category><![CDATA[Windows]]></category>
<category><![CDATA[wordpress]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8223</guid>
<description><![CDATA[<p>In einer Zeit, in der die Integration verschiedener Technologien zunehmend an Bedeutung gewinnt, bietet der “HNP Win Data Handler” eine effiziente Lösung für die sichere Datenübertragung zwischen einer WordPress-Website und einer externen C#-Anwendung. Dieses System stellt eine maßgeschneiderte REST API zur Verfügung, die speziell dafür entwickelt wurde, um von jeder C#-basierten Anwendung aus auf die Daten einer WordPress-Seite zuzugreifen. Was der HNP Win Data Handler macht Der HNP Win Data Handler ist ein WordPress-Plugin kombiniert mit einer C#-Anwendung, die zusammenarbeiten, um Daten sicher zu verwalten und auszutauschen. Das WordPress-Plugin definiert spezifische REST-API-Endpunkte, die es einer C#-Anwendung ermöglichen, Daten zu lesen (GET) und zu schreiben (POST). Diese Daten können für eine Vielzahl von Anwendungen nützlich sein, beispielsweise für das Abrufen und Aktualisieren von Konfigurationseinstellungen, Nutzerdaten oder anderen dynamischen Inhalten, die auf der WordPress-Seite gepflegt werden. Download Exe & WordPress Plugin (sofort kostenlos nutzbar): [sdm_download id=”8231″ fancy=”0″] Shortcode in WordPress für Anzeige der Daten: [hnp_win_data_display] Github: https://github.com/HNP-Christopher-Rohde/Hnp-win-data-handler/tree/main C# Source-Code für die Win EXE / Anwendung: Die C#-Komponente handhabt die Benutzereingaben und interagiert direkt mit der REST-API. Sie bietet Funktionen zum Ändern der Domain-URL, zum Laden von Daten aus WordPress und zum Speichern von Änderungen an den Daten. Diese Flexibilität macht es möglich,....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/27/hnp-win-data-handler-datenaustausch-zwischen-wordpress-windows/">HNP Win Data Handler – Datenaustausch zwischen WordPress & Windows</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p>In einer Zeit, in der die Integration verschiedener Technologien zunehmend an Bedeutung gewinnt, bietet der “HNP Win Data Handler” eine effiziente Lösung für die sichere Datenübertragung zwischen einer WordPress-Website und einer externen C#-Anwendung. Dieses System stellt eine maßgeschneiderte REST API zur Verfügung, die speziell dafür entwickelt wurde, um von jeder C#-basierten Anwendung aus auf die Daten einer WordPress-Seite zuzugreifen.</p>
<p><strong>Was der HNP Win Data Handler macht</strong></p>
<p>Der HNP Win Data Handler ist ein WordPress-Plugin kombiniert mit einer C#-Anwendung, die zusammenarbeiten, um Daten sicher zu verwalten und auszutauschen. Das WordPress-Plugin definiert spezifische REST-API-Endpunkte, die es einer C#-Anwendung ermöglichen, Daten zu lesen (GET) und zu schreiben (POST). Diese Daten können für eine Vielzahl von Anwendungen nützlich sein, beispielsweise für das Abrufen und Aktualisieren von Konfigurationseinstellungen, Nutzerdaten oder anderen dynamischen Inhalten, die auf der WordPress-Seite gepflegt werden.</p>
<p><strong>Download Exe & WordPress Plugin (sofort kostenlos nutzbar):</strong><br />
[sdm_download id=”8231″ fancy=”0″]<br />
Shortcode in WordPress für Anzeige der Daten: [hnp_win_data_display]</p>
<p><strong>Github:</strong><br />
<a href="https://github.com/HNP-Christopher-Rohde/Hnp-win-data-handler/tree/main" rel="nofollow noopener" target="_blank">https://github.com/HNP-Christopher-Rohde/Hnp-win-data-handler/tree/main</a></p>
<p><strong>C# Source-Code für die Win EXE / Anwendung:</strong><br />
Die C#-Komponente handhabt die Benutzereingaben und interagiert direkt mit der REST-API. Sie bietet Funktionen zum Ändern der Domain-URL, zum Laden von Daten aus WordPress und zum Speichern von Änderungen an den Daten. Diese Flexibilität macht es möglich, die Datenverwaltung von jeder C#-basierten Benutzeroberfläche aus zu steuern.</p>
<pre>
// HNP Win Data Handler v.1.0 EXE
// Author: HNP C.R.
// Author URI: https://homepage-nach-preis.de/
// Licence: Creative Commons Non-Commercial
using System;
using System.IO;
using System.Net.Http;
using System.Threading.Tasks;
using Newtonsoft.Json;
class hnp_win_data_Main
{
private static readonly HttpClient client = new HttpClient();
private static string domainFilePath = "hnp_win_data_domain.txt";
private static string? domainUrl = null;
private const string SecretKey = "9418BB768671A389";
static async Task Main(string[] args)
{
client.DefaultRequestHeaders.Add("X-Secret-Key", SecretKey);
await LoadDomain();
while (true)
{
Console.WriteLine("\nMenu:");
Console.WriteLine("1. Change Domain");
Console.WriteLine("2. Load Data from WordPress");
Console.WriteLine("3. Change and Save Data");
Console.Write("Select an option: ");
string? option = Console.ReadLine();
switch (option)
{
case "1":
ChangeDomain();
break;
case "2":
await LoadDataFromWordPress();
break;
case "3":
await ChangeAndSaveData();
break;
default:
Console.WriteLine("Invalid option.");
break;
}
}
}
static async Task LoadDomain()
{
if (File.Exists(domainFilePath))
{
domainUrl = await File.ReadAllTextAsync(domainFilePath) ?? string.Empty;
Console.WriteLine($"Loaded domain: {domainUrl}");
}
else
{
Console.Write("Enter domain URL: ");
domainUrl = Console.ReadLine();
if (!string.IsNullOrWhiteSpace(domainUrl))
{
await File.WriteAllTextAsync(domainFilePath, domainUrl);
}
}
}
static void ChangeDomain()
{
Console.Write("Enter new domain URL: ");
string? newDomainUrl = Console.ReadLine();
if (!string.IsNullOrWhiteSpace(newDomainUrl))
{
domainUrl = newDomainUrl;
File.WriteAllText(domainFilePath, domainUrl);
Console.WriteLine("Domain updated successfully.");
}
else
{
Console.WriteLine("Invalid domain URL provided.");
}
}
static async Task LoadDataFromWordPress()
{
if (!string.IsNullOrWhiteSpace(domainUrl))
{
try
{
HttpResponseMessage response = await client.GetAsync(domainUrl + "/wp-json/hnp-win-data/v1/data");
response.EnsureSuccessStatusCode();
string responseBody = await response.Content.ReadAsStringAsync();
string decodedData = JsonConvert.DeserializeObject<string>(responseBody) ?? "Default or empty data";
Console.WriteLine("Data loaded: " + decodedData);
}
catch (HttpRequestException e)
{
Console.WriteLine("\nException Caught!");
Console.WriteLine("Message :{0} ", e.Message);
}
}
else
{
Console.WriteLine("Domain URL is not set. Please set the domain URL first.");
}
}
static async Task ChangeAndSaveData()
{
Console.Write("Enter new data value: ");
string? newData = Console.ReadLine();
if (!string.IsNullOrWhiteSpace(newData) && !string.IsNullOrWhiteSpace(domainUrl))
{
var content = new StringContent($"\"{newData}\"", System.Text.Encoding.UTF8, "application/json");
try
{
HttpResponseMessage response = await client.PostAsync(domainUrl + "/wp-json/hnp-win-data/v1/data", content);
response.EnsureSuccessStatusCode();
Console.WriteLine("Data saved successfully.");
}
catch (HttpRequestException e)
{
Console.WriteLine("\nException Caught!");
Console.WriteLine("Message :{0} ", e.Message);
}
}
else
{
Console.WriteLine("Invalid data value or domain URL is not set.");
}
}
}
</pre>
<p><strong>PHP Source Code für das WordPress Plugin:</strong><br />
Das Plugin registriert zwei REST-API-Endpunkte: einen für GET-Anfragen, um Daten abzurufen, und einen für POST-Anfragen, um Daten zu aktualisieren. Jede Anfrage wird über eine Funktion verarbeitet, die den geheimen Schlüssel überprüft, um sicherzustellen, dass nur berechtigte Anfragen bearbeitet werden.</p>
<pre>
<?php
/*
Plugin Name: HNP Win Data Handler
Description: Handles data via custom REST API for an external C# application with security enhancements.
Version: 1.0
Author: HNP C.R.
Author URI: https://homepage-nach-preis.de/
License: GPLv3
License URI: https://www.gnu.org/licenses/gpl-3.0.html
Shortcode: hnp_win_data_display
*/
define('HNP_WIN_DATA_SECRET_KEY', '9418BB768671A389'); // Set your secret key here
// Register REST API routes
add_action('rest_api_init', function () {
register_rest_route('hnp-win-data/v1', '/data', array(
'methods' => 'GET',
'callback' => 'hnp_win_data_get_data',
'permission_callback' => 'hnp_win_data_check_secret_key'
));
register_rest_route('hnp-win-data/v1', '/data', array(
'methods' => 'POST',
'callback' => 'hnp_win_data_set_data',
'permission_callback' => 'hnp_win_data_check_secret_key'
));
});
// Function to handle GET request
function hnp_win_data_get_data(WP_REST_Request $request) {
$value = get_option('hnp_win_data_value', 'No data set.');
return new WP_REST_Response($value, 200);
}
// Function to handle POST request
function hnp_win_data_set_data(WP_REST_Request $request) {
$data = $request->get_body();
$clean_data = sanitize_text_field($data);
update_option('hnp_win_data_value', $clean_data);
return new WP_REST_Response('Data updated successfully.', 200);
}
// Permission check to validate secret key
function hnp_win_data_check_secret_key($request) {
$headers = $request->get_headers();
$provided_secret = $headers['x_secret_key'][0] ?? '';
return $provided_secret === HNP_WIN_DATA_SECRET_KEY;
}
// Shortcode to display the data in the frontend
add_shortcode('hnp_win_data_display', 'hnp_win_data_display_shortcode');
function hnp_win_data_display_shortcode() {
$value = get_option('hnp_win_data_value', 'No data set.');
return esc_html($value);
}
</pre>
<p>Der HNP Win Data Handler ist ein Beispiel für die erfolgreiche Integration von Web- und Desktop-Technologien zur Datensynchronisation. Die Kombination aus einem WordPress-Plugin und einer C#-Anwendung bietet eine sichere und flexible Lösung für das Datenmanagement, die in vielen Geschäftsbereichen und Anwendungen nützlich sein kann. Mit seinem modularen Aufbau und der hohen Sicherheit stellt dieses System eine wertvolle Ressource für Entwickler dar, die in gemischten Technologieumgebungen arbeiten.</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/27/hnp-win-data-handler-datenaustausch-zwischen-wordpress-windows/">HNP Win Data Handler – Datenaustausch zwischen WordPress & Windows</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/04/27/hnp-win-data-handler-datenaustausch-zwischen-wordpress-windows/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
</item>
<item>
<title>HNP WIN SHORTCODE Tool: Eine Revolution für WordPress</title>
<link>https://homepage-nach-preis.de/2024/04/26/hnp-win-shortcode-tool-eine-revolution-fuer-wordpress/</link>
<comments>https://homepage-nach-preis.de/2024/04/26/hnp-win-shortcode-tool-eine-revolution-fuer-wordpress/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Fri, 26 Apr 2024 19:13:58 +0000</pubDate>
<category><![CDATA[Allgemein]]></category>
<category><![CDATA[Homepage]]></category>
<category><![CDATA[Onlineshop]]></category>
<category><![CDATA[Webdesign]]></category>
<category><![CDATA[API]]></category>
<category><![CDATA[Daten]]></category>
<category><![CDATA[Hook]]></category>
<category><![CDATA[Shortcode]]></category>
<category><![CDATA[software]]></category>
<category><![CDATA[Verbindung]]></category>
<category><![CDATA[Win]]></category>
<category><![CDATA[Windows]]></category>
<category><![CDATA[wordpress]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8216</guid>
<description><![CDATA[<p>Unbegrenzte Anpassung mit dem HNP WIN SHORTCODE Tool: Eine Revolution für WordPress In der Welt des Webdesigns und der Content-Verwaltungssysteme ist Flexibilität der Schlüssel. WordPress, das beliebte CMS, bietet bereits eine Vielzahl von Funktionen, aber was, wenn Sie noch weiter gehen möchten? Was ist, wenn Sie Ihre Inhalte noch individueller gestalten möchten? Hier kommt das HNP WIN SHORTCODE Tool ins Spiel – ein innovatives WordPress-Plugin in Kombination mit einer leistungsstarken Windows x64-Software, die Ihnen die unbegrenzte Erstellung und Anpassung von Shortcodes ermöglicht. Was ist das HNP WIN SHORTCODE Tool? Das HNP WIN SHORTCODE Tool besteht aus zwei Hauptkomponenten: einem WordPress-Plugin und einer Windows x64-Software. Zusammen ermöglichen sie die einfache Erstellung und Verwaltung von Shortcodes mit anpassbaren Inhalten direkt von Ihrem Desktop aus. Wie funktioniert es? Das WordPress-Plugin integriert sich nahtlos in Ihre WordPress-Installation. Nach der Installation und Aktivierung stehen Ihnen sofort alle Funktionen zur Verfügung. Sie können die Anzahl der Shortcodes festlegen und die Daten bearbeiten, alles direkt über das Backend von WordPress. Die Windows-Software bietet eine benutzerfreundliche Oberfläche, mit der Sie die Shortcodes und deren Inhalte laden und ändern können. Dank der Integration mit der WordPress-Rest-API können Sie die Änderungen direkt auf Ihrer Website veröffentlichen. Funktionen des WordPress-Plugins: Einfache....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/26/hnp-win-shortcode-tool-eine-revolution-fuer-wordpress/">HNP WIN SHORTCODE Tool: Eine Revolution für WordPress</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p><strong>Unbegrenzte Anpassung mit dem HNP WIN SHORTCODE Tool: Eine Revolution für WordPress</strong></p>
<p>In der Welt des Webdesigns und der Content-Verwaltungssysteme ist Flexibilität der Schlüssel. WordPress, das beliebte CMS, bietet bereits eine Vielzahl von Funktionen, aber was, wenn Sie noch weiter gehen möchten? Was ist, wenn Sie Ihre Inhalte noch individueller gestalten möchten? Hier kommt das HNP WIN SHORTCODE Tool ins Spiel – ein innovatives WordPress-Plugin in Kombination mit einer leistungsstarken Windows x64-Software, die Ihnen die unbegrenzte Erstellung und Anpassung von Shortcodes ermöglicht.</p>
<h3>Was ist das HNP WIN SHORTCODE Tool?</h3>
<p>Das HNP WIN SHORTCODE Tool besteht aus zwei Hauptkomponenten: einem WordPress-Plugin und einer Windows x64-Software. Zusammen ermöglichen sie die einfache Erstellung und Verwaltung von Shortcodes mit anpassbaren Inhalten direkt von Ihrem Desktop aus.</p>
<h3>Wie funktioniert es?</h3>
<p>Das WordPress-Plugin integriert sich nahtlos in Ihre WordPress-Installation. Nach der Installation und Aktivierung stehen Ihnen sofort alle Funktionen zur Verfügung. Sie können die Anzahl der Shortcodes festlegen und die Daten bearbeiten, alles direkt über das Backend von WordPress.</p>
<p>Die Windows-Software bietet eine benutzerfreundliche Oberfläche, mit der Sie die Shortcodes und deren Inhalte laden und ändern können. Dank der Integration mit der WordPress-Rest-API können Sie die Änderungen direkt auf Ihrer Website veröffentlichen.</p>
<h3>Funktionen des WordPress-Plugins:</h3>
<ul>
<li><strong>Einfache Einrichtung:</strong> Installieren und aktivieren Sie das Plugin – der Rest ist optional, da das Plugin bereits vorkonfiguriert ist.</li>
<li><strong>Backend-Verwaltung:</strong> Eine eigene Backend-Seite im Admin-Dashboard von WordPress ermöglicht die Verwaltung der Shortcodes und ihrer Inhalte.</li>
<li><strong>Anpassung:</strong> Passen Sie die Anzahl der Shortcodes an und definieren Sie die Daten, die ausgelesen und geändert werden sollen.</li>
<li><strong>Sprachunabhängig:</strong> Das Plugin ist derzeit nur in Englisch verfügbar, aber da Sie die Inhalte der Shortcodes selbst bestimmen können, ist die Sprache irrelevant.</li>
<li><strong>Performance und Sicherheit:</strong> Das Plugin nutzt pures JavaScript und ist mit PHP 7.X und PHP 8.X kompatibel. Die REST-API ist durch einen Secret Key geschützt.</li>
</ul>
<h3>Funktionen der Windows-Software:</h3>
<ul>
<li><strong>Einfache Nutzung:</strong> Starten Sie die Anwendung auf einem Windows-64-Bit-System und geben Sie Ihre Domain-Adresse ein – mehr ist nicht nötig.</li>
<li><strong>Vielseitigkeit:</strong> Die Anwendung funktioniert auf Servern, Laptops und herkömmlichen Computern.</li>
<li><strong>Anpassungsmöglichkeiten:</strong> Ändern Sie den Secret Key, die Anzahl der Shortcodes und die Domain-Adresse nach Bedarf.</li>
<li><strong>Speicherungsfunktion:</strong> Die Anwendung merkt sich die letzten Einstellungen für einen bequemen Autostart.</li>
<li><strong>Performance und Sicherheit:</strong> Nutzt keine externen Bibliotheken außer denen von Python, Netcore und GTK. Die Datenübertragung zur WordPress-Website erfolgt über die REST-API mit einem Secret Key.</li>
</ul>
<p> </p>
<p><strong>Mehr Informationen und Download:</strong><br />
<a href="https://shop.homepage-nach-preis.de/produkt/hnp-unlimiterte-shortcodes-schnitstelle-wordpress-windows-x64/" target="_blank" rel="nofollow noopener">https://shop.homepage-nach-preis.de/produkt/hnp-unlimiterte-shortcodes-schnitstelle-wordpress-windows-x64/</a></p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/26/hnp-win-shortcode-tool-eine-revolution-fuer-wordpress/">HNP WIN SHORTCODE Tool: Eine Revolution für WordPress</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/04/26/hnp-win-shortcode-tool-eine-revolution-fuer-wordpress/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
</item>
<item>
<title>HNP System Monitor Tool: Die Brücke zwischen Windows und WordPress</title>
<link>https://homepage-nach-preis.de/2024/04/20/hnp-system-monitor-tool-die-bruecke-zwischen-windows-und-wordpress/</link>
<comments>https://homepage-nach-preis.de/2024/04/20/hnp-system-monitor-tool-die-bruecke-zwischen-windows-und-wordpress/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Sat, 20 Apr 2024 12:05:49 +0000</pubDate>
<category><![CDATA[Homepage]]></category>
<category><![CDATA[Onlineshop]]></category>
<category><![CDATA[Webdesign]]></category>
<category><![CDATA[Anwendung]]></category>
<category><![CDATA[Exe]]></category>
<category><![CDATA[HNP System Monitor]]></category>
<category><![CDATA[JS]]></category>
<category><![CDATA[Php]]></category>
<category><![CDATA[plugin]]></category>
<category><![CDATA[Pyhton]]></category>
<category><![CDATA[Windows]]></category>
<category><![CDATA[wordpress]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8212</guid>
<description><![CDATA[<p>In der digitalen Welt von heute ist es unerlässlich, den Überblick über die Systemleistung eines Servers oder Computers zu behalten. Das HNP System Monitor Tool bietet hier eine innovative Lösung, indem es eine nahtlose Verbindung zwischen einem Windows-Computer oder Server und einer WordPress-Webseite herstellt. Aber wie funktioniert das genau? Und welche Vorteile bringt diese Verbindung mit sich? Lassen Sie uns einen tieferen Blick darauf werfen. Wie funktioniert das HNP System Monitor Tool? Das HNP System Monitor Tool nutzt eine gesicherte REST API, um die aktuelle Systemauslastung des Windows-Geräts zu erfassen und diese Daten an Ihre WordPress-Webseite zu übertragen. Dort können Sie die Daten in einer visuell strukturierten Form betrachten und analysieren. Das Beste daran? Die Einrichtung ist denkbar einfach. WordPress-Plugin: Starten und Loslegen Das mitgelieferte WordPress-Plugin ist vorkonfiguriert, sodass Sie es lediglich installieren und aktivieren müssen. Es erzeugt eine Backend-Seite in Ihrem WordPress-Admin-Dashboard, auf der Sie die Server- oder Computerleistung in Echtzeit verfolgen können. Die Daten werden ohne Neuladen der Seite aktualisiert, dank AJAX-Requests. Zudem bietet das Plugin visuelle Feedbacks durch farbige Pfeile und eine grafische Anzeige der letzten 100 Datenpunkte. Mit den integrierten Shortcodes können Sie die Daten auch im Frontend Ihrer Webseite anzeigen lassen. Exe Win Anwendung: Einfach....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/20/hnp-system-monitor-tool-die-bruecke-zwischen-windows-und-wordpress/">HNP System Monitor Tool: Die Brücke zwischen Windows und WordPress</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p>In der digitalen Welt von heute ist es unerlässlich, den Überblick über die Systemleistung eines Servers oder Computers zu behalten. Das HNP System Monitor Tool bietet hier eine innovative Lösung, indem es eine nahtlose Verbindung zwischen einem Windows-Computer oder Server und einer WordPress-Webseite herstellt. Aber wie funktioniert das genau? Und welche Vorteile bringt diese Verbindung mit sich? Lassen Sie uns einen tieferen Blick darauf werfen.<br />
Wie funktioniert das HNP System Monitor Tool?</p>
<p>Das HNP System Monitor Tool nutzt eine gesicherte REST API, um die aktuelle Systemauslastung des Windows-Geräts zu erfassen und diese Daten an Ihre WordPress-Webseite zu übertragen. Dort können Sie die Daten in einer visuell strukturierten Form betrachten und analysieren. Das Beste daran? Die Einrichtung ist denkbar einfach.<br />
WordPress-Plugin: Starten und Loslegen</p>
<p>Das mitgelieferte WordPress-Plugin ist vorkonfiguriert, sodass Sie es lediglich installieren und aktivieren müssen. Es erzeugt eine Backend-Seite in Ihrem WordPress-Admin-Dashboard, auf der Sie die Server- oder Computerleistung in Echtzeit verfolgen können. Die Daten werden ohne Neuladen der Seite aktualisiert, dank AJAX-Requests. Zudem bietet das Plugin visuelle Feedbacks durch farbige Pfeile und eine grafische Anzeige der letzten 100 Datenpunkte. Mit den integrierten Shortcodes können Sie die Daten auch im Frontend Ihrer Webseite anzeigen lassen.<br />
Exe Win Anwendung: Einfach und Effizient</p>
<p>Die begleitende Windows-64-Bit-Anwendung ist ebenfalls vorkonfiguriert. Nach dem Start der Anwendung und der Eingabe Ihrer Domain-Adresse übernimmt das System automatisch die Datenerfassung und -übertragung. Sie können den Secretkey, die Intervallzeit und andere Einstellungen direkt in der Anwendung ändern. Praktisch ist auch die Speicherungsfunktion, die die letzten Einstellungen für einen Autostart speichert.<br />
Sicherheit und Performance</p>
<p>Sowohl das WordPress-Plugin als auch die Windows-Anwendung setzen auf hohe Sicherheitsstandards. Mit Nonce-Abfragen, gesicherten AJAX-Verbindungen und Schutz vor XSS-Angriffen sind Ihre Daten stets sicher. Zudem sind beide Systeme performance-optimiert, ohne externe Bibliotheken oder Treiber zu benötigen.<br />
Flexibilität und Erweiterbarkeit</p>
<p>Das HNP System Monitor Tool bietet Ihnen die Freiheit, die Intervallzeit zum Datenaustausch nach Ihren Bedürfnissen anzupassen. Ob alle 2 Sekunden oder einmal täglich – Sie haben die Wahl. Darüber hinaus sind die Sourcefiles sowohl für das WordPress-Plugin als auch für die Windows-Anwendung im Lieferumfang enthalten. Dies ermöglicht erfahreneren Nutzern, das Tool nach Belieben anzupassen und zu erweitern.<br />
Fazit</p>
<p>Das HNP System Monitor Tool ist ein modernes und benutzerfreundliches System zur Erfassung und Visualisierung von Systemdaten. Mit seiner einfachen Einrichtung, hohen Sicherheitsstandards und Flexibilität ist es eine ideale Lösung für jeden, der die Leistung seines Windows-Computers oder Servers im Auge behalten und diese Daten nahtlos in seine WordPress-Webseite integrieren möchte.</p>
<p>Beim Kauf erhalten Sie ein fertiges Run & Go WordPress-Plugin, eine Windows-64-Bit-Anwendung, sowie alle erforderlichen Sourcefiles für Anpassungen und Erweiterungen. Nutzen Sie die Gelegenheit und bringen Sie Ihre Systemüberwachung auf das nächste Level!</p>
<p><strong> Mehr Informationen:</strong></p>
<p><a href="https://shop.homepage-nach-preis.de/produkt/hnp-system-monitor-for-wordpress-windows-x64/" target="_blank" rel="nofollow noopener">https://shop.homepage-nach-preis.de/produkt/hnp-system-monitor-for-wordpress-windows-x64/</a></p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/20/hnp-system-monitor-tool-die-bruecke-zwischen-windows-und-wordpress/">HNP System Monitor Tool: Die Brücke zwischen Windows und WordPress</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/04/20/hnp-system-monitor-tool-die-bruecke-zwischen-windows-und-wordpress/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
</item>
<item>
<title>WooCommerce Warenkorb Leeren & Session Button</title>
<link>https://homepage-nach-preis.de/2024/04/15/woocommerce-warenkorb-leeren-session-button/</link>
<comments>https://homepage-nach-preis.de/2024/04/15/woocommerce-warenkorb-leeren-session-button/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Mon, 15 Apr 2024 14:27:03 +0000</pubDate>
<category><![CDATA[Allgemein]]></category>
<category><![CDATA[Onlineshop]]></category>
<category><![CDATA[Wordpress Code]]></category>
<category><![CDATA[Button]]></category>
<category><![CDATA[leeren]]></category>
<category><![CDATA[Warenkorb]]></category>
<category><![CDATA[Woocommerce]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8204</guid>
<description><![CDATA[<p>Das HNP Warenkorb Leeren Button Plugin für WooCommerce und WordPress erzeugt einen Button auf der Warenkorb-Seite, welcher bei Betätigung den kompletten Warenkorb leert und zudem die Session und Cookies resetet. Download: [sdm_download id=”8202″ fancy=”0″] <?php /** Plugin Name: HNP Clear WooCommerce Cart & Session Description: Ein Plugin zum Leeren des WooCommerce Warenkorbs und Löschen von Sessions und Cookies. Version: 1.2 Author: HNP C.R. Author URI: https://homepage-nach-preis.de/ License: GPLv3 License URI: https://www.gnu.org/licenses/gpl-3.0.html */ // Exit, wenn der Direktzugriff verhindert ist if (!defined('ABSPATH')) { exit; } function hnp_cwc_enqueue_scripts() { if (is_cart() && get_option('hnp_cwc_enable', 'no') == 'yes' && get_option('hnp_cwc_hook_enable', 'no') == 'yes') { $nonce = wp_create_nonce('hnp_cwc_nonce'); $script = " var ajaxurl = '" . admin_url('admin-ajax.php') . "'; var nonce = '" . $nonce . "'; document.addEventListener('DOMContentLoaded', function() { var clearCartButton = document.getElementById('clear-cart'); clearCartButton.addEventListener('click', function() { // Clear cart var xhr = new XMLHttpRequest(); xhr.open('POST', ajaxurl, true); xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); xhr.setRequestHeader('X-WP-Nonce', nonce); xhr.onload = function() { if (this.status >= 200 && this.status < 400) { console.log('Cart Cleared', this.responseText); // Clear sessions and cookies var xhr2 = new XMLHttpRequest(); xhr2.open('POST', ajaxurl, true); xhr2.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); xhr2.setRequestHeader('X-WP-Nonce', nonce); xhr2.onload = function() { if (this.status >= 200 && this.status < 400) { console.log('Sessions and Cookies Cleared', this.responseText); // Reload....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/15/woocommerce-warenkorb-leeren-session-button/">WooCommerce Warenkorb Leeren & Session Button</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p>Das HNP Warenkorb Leeren Button Plugin für WooCommerce und WordPress erzeugt einen Button auf der Warenkorb-Seite, welcher bei Betätigung den kompletten Warenkorb leert und zudem die Session und Cookies resetet.</p>
<p><strong>Download: </strong><br />
[sdm_download id=”8202″ fancy=”0″]</p>
<pre>
<?php
/**
Plugin Name: HNP Clear WooCommerce Cart & Session
Description: Ein Plugin zum Leeren des WooCommerce Warenkorbs und Löschen von Sessions und Cookies.
Version: 1.2
Author: HNP C.R.
Author URI: https://homepage-nach-preis.de/
License: GPLv3
License URI: https://www.gnu.org/licenses/gpl-3.0.html
*/
// Exit, wenn der Direktzugriff verhindert ist
if (!defined('ABSPATH')) {
exit;
}
function hnp_cwc_enqueue_scripts() {
if (is_cart() && get_option('hnp_cwc_enable', 'no') == 'yes' && get_option('hnp_cwc_hook_enable', 'no') == 'yes') {
$nonce = wp_create_nonce('hnp_cwc_nonce');
$script = "
var ajaxurl = '" . admin_url('admin-ajax.php') . "';
var nonce = '" . $nonce . "';
document.addEventListener('DOMContentLoaded', function() {
var clearCartButton = document.getElementById('clear-cart');
clearCartButton.addEventListener('click', function() {
// Clear cart
var xhr = new XMLHttpRequest();
xhr.open('POST', ajaxurl, true);
xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xhr.setRequestHeader('X-WP-Nonce', nonce);
xhr.onload = function() {
if (this.status >= 200 && this.status < 400) {
console.log('Cart Cleared', this.responseText);
// Clear sessions and cookies
var xhr2 = new XMLHttpRequest();
xhr2.open('POST', ajaxurl, true);
xhr2.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xhr2.setRequestHeader('X-WP-Nonce', nonce);
xhr2.onload = function() {
if (this.status >= 200 && this.status < 400) {
console.log('Sessions and Cookies Cleared', this.responseText);
// Reload the page after clearing cart and sessions/cookies
location.reload();
} else {
console.error('Error clearing sessions and cookies', this);
}
};
xhr2.onerror = function() {
console.error('Error clearing sessions and cookies', this);
};
xhr2.send('action=hnp_clear_sessions_cookies&nonce=' + nonce);
} else {
console.error('Error clearing cart', this);
}
};
xhr.onerror = function() {
console.error('Error clearing cart', this);
};
xhr.send('action=hnp_clear_cart_session&nonce=' + nonce);
});
});
";
wp_add_inline_script('jquery', $script);
}
}
add_action('wp_enqueue_scripts', 'hnp_cwc_enqueue_scripts');
// Register shortcode
function hnp_cwc_button_shortcode() {
ob_start(); ?>
<button id="clear-cart">Warenkorb leeren</button>
<?php
return ob_get_clean();
}
add_shortcode('hnp_cwc_button', 'hnp_cwc_button_shortcode');
// Hook to display the button on cart page
function hnp_cwc_display_button() {
if (get_option('hnp_cwc_hook_enable', 'no') == 'yes') {
echo do_shortcode('[hnp_cwc_button]');
}
}
add_action('woocommerce_cart_actions', 'hnp_cwc_display_button');
// AJAX handler to clear cart
function hnp_cwc_clear_cart() {
check_ajax_referer('hnp_cwc_nonce', 'nonce');
try {
WC()->cart->empty_cart();
echo 'Cart Cleared';
} catch (Exception $e) {
echo 'Error clearing cart: ' . $e->getMessage();
}
die();
}
add_action('wp_ajax_hnp_clear_cart_session', 'hnp_cwc_clear_cart');
add_action('wp_ajax_nopriv_hnp_clear_cart_session', 'hnp_cwc_clear_cart');
</pre>
<pre>
// AJAX handler to clear sessions and cookies
function hnp_cwc_clear_sessions_cookies() {
check_ajax_referer('hnp_cwc_nonce', 'nonce');
try {
// Reset WooCommerce session
WC()->session->set_customer_session_cookie(false);
WC()->session->set_session_cookie(false);
WC()->session->reset_session();
// Unset all cookies
foreach ($_COOKIE as $cookie_key => $cookie_value) {
unset($_COOKIE[$cookie_key]);
setcookie($cookie_key, '', time() - 3600, '/', $_SERVER['HTTP_HOST']);
setcookie($cookie_key, '', time() - 3600, '/', '.' . $_SERVER['HTTP_HOST']);
}
echo 'Sessions and Cookies Cleared';
} catch (Exception $e) {
echo 'Error clearing sessions and cookies: ' . $e->getMessage();
}
die();
}
add_action('wp_ajax_hnp_clear_sessions_cookies', 'hnp_cwc_clear_sessions_cookies');
add_action('wp_ajax_nopriv_hnp_clear_sessions_cookies', 'hnp_cwc_clear_sessions_cookies');
// Admin settings
function hnp_cwc_admin_menu() {
add_menu_page(
'HNP Clear WooCommerce Cart Settings',
'HNP Clear WooCommerce Cart',
'manage_options',
'hnp_cwc_settings',
'hnp_cwc_settings_page',
		 plugin_dir_url(__FILE__) . 'img/hnp-favi.png'
);
}
add_action('admin_menu', 'hnp_cwc_admin_menu');
function hnp_cwc_settings_page() {
	if (!current_user_can('manage_options')) {
return;
}
if ($_SERVER['REQUEST_METHOD'] === 'POST' && check_admin_referer('hnp_cwc_nonce', 'hnp_cwc_nonce_field')) {
if (isset($_POST['hnp_cwc_enable'])) {
update_option('hnp_cwc_enable', $_POST['hnp_cwc_enable']);
} else {
update_option('hnp_cwc_enable', 'no');
}
if (isset($_POST['hnp_cwc_hook_enable'])) {
update_option('hnp_cwc_hook_enable', $_POST['hnp_cwc_hook_enable']);
} else {
update_option('hnp_cwc_hook_enable', 'no');
}
}
$enabled = get_option('hnp_cwc_enable', 'no');
$hook_enabled = get_option('hnp_cwc_hook_enable', 'no');
$nonce = wp_create_nonce('hnp_cwc_nonce');
?>
<div class="wrap">
<h2>HNP Clear WooCommerce Cart Settings</h2>
<form method="post" action="">
<?php wp_nonce_field('hnp_cwc_nonce', 'hnp_cwc_nonce_field'); ?>
<table class="form-table">
<tr>
<th scope="row">Allgemeine Funktion aktivieren</th>
<td>
<input type="checkbox" name="hnp_cwc_enable" value="yes" <?php checked('yes', $enabled); ?> />
</td>
</tr>
<tr>
<th scope="row">Hook für Warenkorb aktivieren</th>
<td>
<input type="checkbox" name="hnp_cwc_hook_enable" value="yes" <?php checked('yes', $hook_enabled); ?> />
</td>
</tr>
				<tr>Shortcode um den Button manuell einzubinden: [hnp_cwc_button]</tr>
</table>
<?php submit_button(); ?>
</form>
</div>
<?php
}
</pre>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/15/woocommerce-warenkorb-leeren-session-button/">WooCommerce Warenkorb Leeren & Session Button</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/04/15/woocommerce-warenkorb-leeren-session-button/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
</item>
<item>
<title>HNP Empty Plugin – WordPress Demo Code</title>
<link>https://homepage-nach-preis.de/2024/04/10/hnp-empty-plugin-wordpress-demo-code/</link>
<comments>https://homepage-nach-preis.de/2024/04/10/hnp-empty-plugin-wordpress-demo-code/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Wed, 10 Apr 2024 13:54:30 +0000</pubDate>
<category><![CDATA[Allgemein]]></category>
<category><![CDATA[Wordpress Code]]></category>
<category><![CDATA[Beispiel]]></category>
<category><![CDATA[Code]]></category>
<category><![CDATA[Demo]]></category>
<category><![CDATA[Empty]]></category>
<category><![CDATA[Leeres]]></category>
<category><![CDATA[plugin]]></category>
<category><![CDATA[wordpress]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8186</guid>
<description><![CDATA[<p>Das HNP Empty Plugin ist ein einfaches Demo-Plugin für WordPress, das entwickelt wurde, um grundlegende Funktionen eines Plugins zu demonstrieren. Es zeigt, wie man Styles und Skripte sowohl im Frontend als auch im Backend von WordPress einbindet. Außerdem bietet es eine Benutzeroberfläche zur Verwaltung von Plugin-Optionen über das WordPress-Dashboard. Der Plugin-Demo Code besitzt alle wichtigen Sicherheitsoptionen und Code-Qualitätsanforderungen, damit ein Plugin im offiziellen WordPress Verzeichnis aufgenommen wird. Zudem Funktionen, welche im Jahr 2024 auf dem neuesten Stand sind. Somit eine gute Grundlage für WordPress-Plugin-Entwickler. Geteste Kompatibilität: WordPress 6.5.2 und PHP 8.3. Das Plugin wird aber auch mit neueren und älteren PHP und WordPress Versionen kompatibel sein. Features: Frontend und Backend Styling: Das Plugin fügt sowohl dem Frontend als auch dem Backend von WordPress benutzerdefinierte CSS- und JavaScript-Dateien hinzu, um das Erscheinungsbild anzupassen. Plugin-Optionen: Es bietet eine einfache Möglichkeit, Plugin-Optionen über das WordPress-Dashboard zu konfigurieren, einschließlich Textfelder, Zahlenfelder, Farbwähler, Dropdown-Listen und Checkboxen. Shortcode: Das Plugin stellt einen Shortcode bereit, mit dem Benutzer die konfigurierten Optionen auf beliebigen Seiten oder Beiträgen anzeigen können. Sicherheitsmaßnahmen: Das Plugin implementiert Sicherheitsmaßnahmen wie Nonce-Überprüfung, um unerwünschte Zugriffe auf die Plugin-Einstellungen zu verhindern.   Plugin-Download: [sdm_download id=”8187″ fancy=”0″] Github: https://github.com/HNP-Christopher-Rohde/hnp_empty_wordpress_plugin Quellcode: <?php /* Plugin Name: HNP Empty....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/10/hnp-empty-plugin-wordpress-demo-code/">HNP Empty Plugin – WordPress Demo Code</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p>Das HNP Empty Plugin ist ein einfaches Demo-Plugin für WordPress, das entwickelt wurde, um grundlegende Funktionen eines Plugins zu demonstrieren. Es zeigt, wie man Styles und Skripte sowohl im Frontend als auch im Backend von WordPress einbindet. Außerdem bietet es eine Benutzeroberfläche zur Verwaltung von Plugin-Optionen über das WordPress-Dashboard. Der Plugin-Demo Code besitzt alle wichtigen Sicherheitsoptionen und Code-Qualitätsanforderungen, damit ein Plugin im offiziellen WordPress Verzeichnis aufgenommen wird. Zudem Funktionen, welche im Jahr 2024 auf dem neuesten Stand sind. Somit eine gute Grundlage für WordPress-Plugin-Entwickler. Geteste Kompatibilität: WordPress 6.5.2 und PHP 8.3. Das Plugin wird aber auch mit neueren und älteren PHP und WordPress Versionen kompatibel sein. </p>
<p><strong>Features:</strong></p>
<ul>
<li><strong>Frontend und Backend Styling:</strong> Das Plugin fügt sowohl dem Frontend als auch dem Backend von WordPress benutzerdefinierte CSS- und JavaScript-Dateien hinzu, um das Erscheinungsbild anzupassen.</li>
<li><strong>Plugin-Optionen:</strong> Es bietet eine einfache Möglichkeit, Plugin-Optionen über das WordPress-Dashboard zu konfigurieren, einschließlich Textfelder, Zahlenfelder, Farbwähler, Dropdown-Listen und Checkboxen.</li>
<li><strong>Shortcode:</strong> Das Plugin stellt einen Shortcode bereit, mit dem Benutzer die konfigurierten Optionen auf beliebigen Seiten oder Beiträgen anzeigen können.</li>
<li><strong>Sicherheitsmaßnahmen:</strong> Das Plugin implementiert Sicherheitsmaßnahmen wie Nonce-Überprüfung, um unerwünschte Zugriffe auf die Plugin-Einstellungen zu verhindern.</li>
</ul>
<p> </p>
<p><strong>Plugin-Download:</strong> [sdm_download id=”8187″ fancy=”0″]<br />
<strong>Github:</strong> <a href="https://github.com/HNP-Christopher-Rohde/hnp_empty_wordpress_plugin" target="_blank" rel="nofollow noopener">https://github.com/HNP-Christopher-Rohde/hnp_empty_wordpress_plugin</a><br />
<strong>Quellcode:</strong></p>
<pre><?php
/*
Plugin Name: HNP Empty Plugin
Description: Creates a Demo Plugin in WordPress
Version: 2.0
Author: HNP C.R.
Author URI: https://homepage-nach-preis.de/
License: GPLv3
License URI: https://www.gnu.org/licenses/gpl-3.0.html
*/
// Security check to prevent direct access to the plugin file
defined('ABSPATH') or die('No script kiddies please!');
// Function to enqueue the Frontend CSS and JS
function hnp_empty_plugin_frontend_scripts() {
// Define a version number
$version = '2.0';
// Check if CSS is not already enqueued
if (!wp_style_is('hnp_empty_plugin_frontend-css')) {
// Enqueue CSS with the defined version
wp_enqueue_style('hnp_empty_plugin_frontend-css', plugin_dir_url(__FILE__) . '/frontend/css/hnp_empty_plugin_frontend.css', array(), $version);
}
// Check if JavaScript is not already enqueued
if (!wp_script_is('hnp_empty_plugin_frontend-js')) {
// Enqueue JavaScript with the defined version
wp_enqueue_script('hnp_empty_plugin_frontend-js', plugin_dir_url(__FILE__) . '/frontend/js/hnp_empty_plugin_frontend.js', array(), $version, true);
}
}
add_action('wp_enqueue_scripts', 'hnp_empty_plugin_frontend_scripts');
// Function to enqueue Backend CSS and JS
function hnp_empty_plugin_backend_scripts() {
// Define a version number
$version = '2.0';
// Check if CSS is not already enqueued
if (!wp_style_is('hnp_empty_plugin_backend-css')) {
// Enqueue CSS with the defined version
wp_enqueue_style('hnp_empty_plugin_backend-css', plugin_dir_url(__FILE__) . '/backend/css/hnp_empty_plugin_backend.css', array(), $version);
}
// Check if JavaScript is not already enqueued
if (!wp_script_is('hnp_empty_plugin_backend-js')) {
// Enqueue JavaScript with the defined version
wp_enqueue_script('hnp_empty_plugin_backend-js', plugin_dir_url(__FILE__) . '/backend/js/hnp_empty_plugin_backend.js', array(), $version, true);
}
}
add_action('admin_enqueue_scripts', 'hnp_empty_plugin_backend_scripts');
// Function for Test - with load Options and Fallback
function hnp_empty_plugin_echo_func() {
// Get option values
$name = get_option('hnp_empty_plugin_name_field', 'Name');
$number = get_option('hnp_empty_plugin_number_field', '12');
$color = get_option('hnp_empty_plugin_color_field', '#ff0000');
$description = get_option('hnp_empty_plugin_description_field', 'Im a Desc Field');
$dropdown = get_option('hnp_empty_plugin_dropdown_field', 'option1');
$checkbox = get_option('hnp_empty_plugin_checkbox_field', 0);
// Echo option values
echo '<p>Name Field: ' . esc_html($name) . '</p>';
echo '<p>Number Field: ' . esc_html($number) . '</p>';
echo '<p>Color Field: ' . esc_html($color) . '</p>';
echo '<p>Description Field: ' . esc_html($description) . '</p>';
echo '<p>Dropdown Field: ' . esc_html($dropdown) . '</p>';
echo '<p>Checkbox Field: ' . ($checkbox ? 'Enabled' : 'Disabled') . '</p>';
}
add_shortcode('hnp_empty_plugin_echo_func', 'hnp_empty_plugin_echo_func');
// Function to add plugin options to the main menu
function hnp_empty_plugin_add_plugin_options_page() {
// Check permission
if (current_user_can('manage_options')) {
add_menu_page(
'HNP Empty Plugin Settings',
'HNP Empty Plugin',
'manage_options',
'hnp-empty-plugin-settings',
'hnp_empty_plugin_render_plugin_options_page',
plugin_dir_url(__FILE__) . 'img/hnp-favi.png'
);
}
}
add_action('admin_menu', 'hnp_empty_plugin_add_plugin_options_page');
// Function to render plugin options page
function hnp_empty_plugin_render_plugin_options_page() {
?>
<div class="wrap hnp-empty-plugin-settings">
<h1>HNP Empty Plugin Settings</h1>
<form method="post" action="options.php">
<?php settings_fields('hnp_empty_plugin_settings_group'); ?>
<?php do_settings_sections('hnp-empty-plugin-settings'); ?>
<?php
// Add nonce
wp_nonce_field('hnp_empty_plugin_settings_nonce', 'hnp_empty_plugin_settings_nonce');
?>
<?php submit_button(); ?>
</form>
</div>
<?php
}
// Function to register plugin options
function hnp_empty_plugin_register_plugin_options() {
// Name
add_settings_section(
'hnp_empty_plugin_name_section',
'Demo',
'hnp_empty_plugin_demo_section_callback',
'hnp-empty-plugin-settings'
);
// Name
add_settings_field(
'hnp_empty_plugin_name_field',
'Name Field',
'hnp_empty_plugin_name_field_callback',
'hnp-empty-plugin-settings',
'hnp_empty_plugin_name_section'
);
// Number
add_settings_field(
'hnp_empty_plugin_number_field',
'Number Field',
'hnp_empty_plugin_number_field_callback',
'hnp-empty-plugin-settings',
'hnp_empty_plugin_name_section'
);
// Color
add_settings_field(
'hnp_empty_plugin_color_field',
'Color Field',
'hnp_empty_plugin_color_field_callback',
'hnp-empty-plugin-settings',
'hnp_empty_plugin_name_section'
);
// Description
add_settings_field(
'hnp_empty_plugin_description_field',
'Description Field',
'hnp_empty_plugin_description_field_callback',
'hnp-empty-plugin-settings',
'hnp_empty_plugin_name_section'
);
// Dropdown
add_settings_field(
'hnp_empty_plugin_dropdown_field',
'Dropdown Field',
'hnp_empty_plugin_dropdown_field_callback',
'hnp-empty-plugin-settings',
'hnp_empty_plugin_name_section'
);
// Checkbox
add_settings_field(
'hnp_empty_plugin_checkbox_field',
'Checkbox Field',
'hnp_empty_plugin_checkbox_field_callback',
'hnp-empty-plugin-settings',
'hnp_empty_plugin_name_section'
);
}
add_action('admin_init', 'hnp_empty_plugin_register_plugin_options');
</pre>
<pre>
// Callback function for demo section
function hnp_empty_plugin_demo_section_callback() {
echo 'This a Demo Plugin. Frontend-Shortcode: &#x5B;hnp_empty_plugin_echo_func]</p>';
}
// Callback function for name field
function hnp_empty_plugin_name_field_callback() {
$value = get_option('hnp_empty_plugin_name_field', 'Name'); // Fallback value is 'Name'
echo '<input type="text" name="hnp_empty_plugin_name_field" value="' . esc_attr($value) . '" />';
}
// Callback functions for number fields
function hnp_empty_plugin_number_field_callback() {
$value = get_option('hnp_empty_plugin_number_field', '12'); // Fallback value is '12'
echo '<input type="number" name="hnp_empty_plugin_number_field" value="' . esc_attr($value) . '" />';
}
// Callback function for Color Field
function hnp_empty_plugin_color_field_callback() {
$value = get_option('hnp_empty_plugin_color_field', '#ff0000'); // Fallback value is red color
echo '<input type="color" name="hnp_empty_plugin_color_field" value="' . esc_attr($value) . '" />';
}
// Callback function for Description Field
function hnp_empty_plugin_description_field_callback() {
$value = get_option('hnp_empty_plugin_description_field', 'Im a Desc Field'); // Fallback value is 'Im a Desc Field'
echo '<textarea name="hnp_empty_plugin_description_field">' . esc_html($value) . '</textarea>';
}
// Callback function for dropdown field
function hnp_empty_plugin_dropdown_field_callback() {
$value = get_option('hnp_empty_plugin_dropdown_field', 'option1'); // Fallback value is 'option1'
?>
<select name="hnp_empty_plugin_dropdown_field">
<option value="option1" <?php selected($value, 'option1'); ?>>Option 1</option>
<option value="option2" <?php selected($value, 'option2'); ?>>Option 2</option>
<option value="option3" <?php selected($value, 'option3'); ?>>Option 3</option>
</select>
<?php
}
// Callback function for checkbox field
function hnp_empty_plugin_checkbox_field_callback() {
$value = get_option('hnp_empty_plugin_checkbox_field', 0); // Fallback value is 0 (not checked)
?>
<label for="hnp_empty_plugin_checkbox_field">
<input type="checkbox" name="hnp_empty_plugin_checkbox_field" id="hnp_empty_plugin_checkbox_field" value="1" <?php checked($value, 1); ?>>
Enable Checkbox
</label>
<?php
}
// Security measures: Nonce verification and save options
function hnp_empty_plugin_register_security_options() {
// Check if the current page is our plugin options page
if (isset($_POST['option_page']) && $_POST['option_page'] == 'hnp_empty_plugin_settings_group') {
// Check if the nonce is set and valid
if (!isset($_POST['hnp_empty_plugin_settings_nonce']) || !wp_verify_nonce($_POST['hnp_empty_plugin_settings_nonce'], 'hnp_empty_plugin_settings_nonce')) {
// Unauthorized request, do not save options
wp_die('Unauthorized request.'); // Output error message for unauthorized requests
}
// Save options
update_option('hnp_empty_plugin_name_field', $_POST['hnp_empty_plugin_name_field']);
update_option('hnp_empty_plugin_number_field', sanitize_text_field($_POST['hnp_empty_plugin_number_field']));
update_option('hnp_empty_plugin_color_field', sanitize_text_field($_POST['hnp_empty_plugin_color_field']));
update_option('hnp_empty_plugin_description_field', sanitize_textarea_field($_POST['hnp_empty_plugin_description_field']));
update_option('hnp_empty_plugin_dropdown_field', sanitize_text_field($_POST['hnp_empty_plugin_dropdown_field']));
update_option('hnp_empty_plugin_checkbox_field', isset($_POST['hnp_empty_plugin_checkbox_field']) ? 1 : 0);
}
}
add_action('admin_init', 'hnp_empty_plugin_register_security_options');
// Register plugin options and security measures
function hnp_empty_plugin_register_settings() {
// Register setting and sanitize callback
register_setting('hnp_empty_plugin_settings_group', 'hnp_empty_plugin_name_field');
register_setting('hnp_empty_plugin_settings_group', 'hnp_empty_plugin_number_field');
register_setting('hnp_empty_plugin_settings_group', 'hnp_empty_plugin_color_field');
register_setting('hnp_empty_plugin_settings_group', 'hnp_empty_plugin_description_field');
register_setting('hnp_empty_plugin_settings_group', 'hnp_empty_plugin_dropdown_field');
register_setting('hnp_empty_plugin_settings_group', 'hnp_empty_plugin_checkbox_field');
}
add_action('admin_init', 'hnp_empty_plugin_register_settings');
// Security measures: Nonce verification for options update
function hnp_empty_plugin_validate_settings($input) {
return $input; // Simply return the input, no further validation here
}
</pre>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/10/hnp-empty-plugin-wordpress-demo-code/">HNP Empty Plugin – WordPress Demo Code</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/04/10/hnp-empty-plugin-wordpress-demo-code/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
</item>
<item>
<title>HNP OpenStreetMap kostenloses Plugin</title>
<link>https://homepage-nach-preis.de/2024/04/10/hnp-openstreetmap-kostenloses-plugin/</link>
<comments>https://homepage-nach-preis.de/2024/04/10/hnp-openstreetmap-kostenloses-plugin/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Wed, 10 Apr 2024 10:19:20 +0000</pubDate>
<category><![CDATA[Allgemein]]></category>
<category><![CDATA[Homepage]]></category>
<category><![CDATA[Wordpress Code]]></category>
<category><![CDATA[Karte]]></category>
<category><![CDATA[kostenlos]]></category>
<category><![CDATA[Openmaps]]></category>
<category><![CDATA[OpenStreetMap]]></category>
<category><![CDATA[plugin]]></category>
<category><![CDATA[Shortcode]]></category>
<category><![CDATA[wordpress]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8176</guid>
<description><![CDATA[<p>Das “HNP OpenStreetMap Shortcode” Plugin ermöglicht es Benutzern, OpenStreetMap-Karten mit einem Pin direkt auf ihrer WordPress-Website einzubetten, indem sie einen Shortcode verwenden. Es bietet eine einfache Möglichkeit, einen Standort auf einer interaktiven Karte zu markieren.   Hier sind die Hauptmerkmale des Plugins: Shortcode-Unterstützung: Benutzer können den bereitgestellten Shortcode verwenden, um eine Karte mit einem Pin an einem bestimmten Standort anzuzeigen. Anpassbare Optionen: Das Plugin bietet verschiedene anpassbare Optionen, darunter die Möglichkeit, die Adresse des Pins, den Namen des Markers, den Zoomlevel der Karte, den Kartenstil sowie die Höhe und Breite der Karte anzupassen. Integrierte Sicherheitsmaßnahmen: Das Plugin enthält Sicherheitsmaßnahmen wie Nonce-Überprüfung, um unautorisierte Zugriffe auf die Plugin-Optionen zu verhindern und die Datenintegrität zu gewährleisten. Einfache Konfiguration: Benutzer können die Plugin-Optionen über das WordPress-Adminpanel konfigurieren, um ihre Karten entsprechend ihren Anforderungen anzupassen. Das Plugin wurde von Homepage-nach-Preis.de entwickelt und steht unter der GNU General Public License Version 3 (GPLv3), was bedeutet, dass es kostenlos verwendet und modifiziert werden kann, solange die Lizenzbedingungen eingehalten werden. Download: [sdm_download id=”8174″ fancy=”0″] Github: https://github.com/HNP-Christopher-Rohde/hnp-openstreetmap-wordpress-plugin/tree/main/hnp_openstreetmap Quellcode: <?php /* Plugin Name: HNP OpenStreetMap Shortcode Description: Creates a frontend OpenStreetMap map with a pin using a shortcode Version: 1.0 Author: HNP - C.R. Author URI: https://homepage-nach-preis.de/ License: GPLv3....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/10/hnp-openstreetmap-kostenloses-plugin/">HNP OpenStreetMap kostenloses Plugin</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p>Das “HNP OpenStreetMap Shortcode” Plugin ermöglicht es Benutzern, OpenStreetMap-Karten mit einem Pin direkt auf ihrer WordPress-Website einzubetten, indem sie einen Shortcode verwenden. Es bietet eine einfache Möglichkeit, einen Standort auf einer interaktiven Karte zu markieren.</p>
<p> </p>
<p>Hier sind die Hauptmerkmale des Plugins:</p>
<ol>
<li><strong>Shortcode-Unterstützung:</strong> Benutzer können den bereitgestellten Shortcode verwenden, um eine Karte mit einem Pin an einem bestimmten Standort anzuzeigen.</li>
<li><strong>Anpassbare Optionen:</strong> Das Plugin bietet verschiedene anpassbare Optionen, darunter die Möglichkeit, die Adresse des Pins, den Namen des Markers, den Zoomlevel der Karte, den Kartenstil sowie die Höhe und Breite der Karte anzupassen.</li>
<li><strong>Integrierte Sicherheitsmaßnahmen:</strong> Das Plugin enthält Sicherheitsmaßnahmen wie Nonce-Überprüfung, um unautorisierte Zugriffe auf die Plugin-Optionen zu verhindern und die Datenintegrität zu gewährleisten.</li>
<li><strong>Einfache Konfiguration:</strong> Benutzer können die Plugin-Optionen über das WordPress-Adminpanel konfigurieren, um ihre Karten entsprechend ihren Anforderungen anzupassen.</li>
</ol>
<p>Das Plugin wurde von Homepage-nach-Preis.de entwickelt und steht unter der GNU General Public License Version 3 (GPLv3), was bedeutet, dass es kostenlos verwendet und modifiziert werden kann, solange die Lizenzbedingungen eingehalten werden.</p>
<p><strong>Download:</strong> [sdm_download id=”8174″ fancy=”0″]</p>
<p><strong>Github:</strong> <a href="https://github.com/HNP-Christopher-Rohde/hnp-openstreetmap-wordpress-plugin/tree/main/hnp_openstreetmap" target="_blank" rel="nofollow noopener">https://github.com/HNP-Christopher-Rohde/hnp-openstreetmap-wordpress-plugin/tree/main/hnp_openstreetmap</a><br />
<strong>Quellcode:</strong></p>
<pre>
<?php
/*
Plugin Name: HNP OpenStreetMap Shortcode
Description: Creates a frontend OpenStreetMap map with a pin using a shortcode
Version: 1.0
Author: HNP - C.R.
Author URI: https://homepage-nach-preis.de/
License: GPLv3
License URI: https://www.gnu.org/licenses/gpl-3.0.html
*/
// Security check to prevent direct access to the plugin file
defined('ABSPATH') or die('No script kiddies please!');
// Function to enqueue Leaflet library
function hnp_openmaps_enqueue_leaflet_scripts() {
// Define a version number for your CSS file
$version = '1.9.4';
// Check if Leaflet CSS is not already enqueued
if (!wp_style_is('leaflet-css')) {
// Enqueue Leaflet CSS with the defined version
wp_enqueue_style('leaflet-css', plugin_dir_url(__FILE__) . 'leaflet/leaflet.css', array(), $version);
}
// Check if Leaflet JavaScript is not already enqueued
if (!wp_script_is('leaflet-js')) {
// Enqueue Leaflet JavaScript with the defined version
wp_enqueue_script('leaflet-js', plugin_dir_url(__FILE__) . 'leaflet/leaflet.js', array(), $version, true);
}
}
add_action('wp_enqueue_scripts', 'hnp_openmaps_enqueue_leaflet_scripts');
// Function to display OpenStreetMap maps with a pin
function hnp_openmaps_display_map_with_pin() {
// Load options and sanitize address
$raw_address = get_option('hnp_openmaps_map_address', 'Hardenbergpl. 8, 10787 Berlin, Germany');
$clean_address = sanitize_text_field($raw_address);
// Load options and sanitize marker name
$marker_name = get_option('hnp_openmaps_map_name', 'Berlin Zoological Garden');
// Load zoom level, map style, height, and width of the map
$zoom = get_option('hnp_openmaps_map_zoom', 12);
$style = get_option('hnp_openmaps_map_style', 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png');
$height = get_option('hnp_openmaps_map_height', '400px');
$width = get_option('hnp_openmaps_map_width', '100%');
// JavaScript variable for map initialization and adding markers
$map = "
<script>
document.addEventListener('DOMContentLoaded', function() {
";
// Split address into individual parts and encode
$address_parts = explode(',', $clean_address);
$encoded_address_parts = array_map('urlencode', $address_parts);
$encoded_address = implode(',', $encoded_address_parts);
// Construct Nominatim URL
$nominatim_url = "https://nominatim.openstreetmap.org/search?format=json&q={$encoded_address}";
// Get geocoding data from Nominatim
$response = wp_remote_get($nominatim_url);
// Check if the request was successful
if (!is_wp_error($response) && wp_remote_retrieve_response_code($response) === 200) {
$data = json_decode(wp_remote_retrieve_body($response), true);
// Check if geocoding results were obtained
if (!empty($data)) {
$latitude = $data[0]['lat'];
$longitude = $data[0]['lon'];
// Initialize map with center at marker coordinates
$map .= "
var hnp_openmaps_map = L.map('hnp_openmaps_map').setView([$latitude, $longitude], $zoom);
";
// Add tiles to the map
$map .= "
L.tileLayer('$style', {
attribution: '&copy; <a href=\"https://www.openstreetmap.org/copyright\">OpenStreetMap</a> contributors'
}).addTo(hnp_openmaps_map);
";
// Add marker to the map
$map .= "
L.marker([$latitude, $longitude]).addTo(hnp_openmaps_map).bindPopup('" . esc_js($clean_address) . "').bindTooltip('" . esc_js($marker_name) . "');
console.log('Geocoding successful for address:', " . wp_json_encode($clean_address) . ");
";
} else {
// Error retrieving geocoding data
error_log("Error retrieving geocoding data for address: $clean_address");
$map .= "
console.log('Error retrieving geocoding data for address:', " . wp_json_encode($clean_address) . ");
";
}
} else {
// Error retrieving geocoding data
error_log("Error retrieving geocoding data for address: $clean_address");
$map .= "
console.log('Error retrieving geocoding data for address:', " . wp_json_encode($clean_address) . ");
";
}
// Add JavaScript end
$map .= "
});
</script>
";
// Return map div and JavaScript
return '<div id="hnp_openmaps_map" style="height: ' . esc_attr($height) . '; width: ' . esc_attr($width) . ';"></div>' . $map;
}
// Register shortcode
add_shortcode('hnp_openmaps_display_map_with_pin', 'hnp_openmaps_display_map_with_pin');
// Function to add plugin options to the main menu
function hnp_openmaps_add_plugin_options_page() {
// Check permission
if (current_user_can('manage_options')) {
add_menu_page(
'HNP OpenStreetMap Settings',
'HNP OpenStreetMap',
'manage_options',
'hnp-openmaps-osm-settings',
'hnp_openmaps_render_plugin_options_page',
plugin_dir_url(__FILE__) . 'img/hnp-favi.png'
);
}
}
add_action('admin_menu', 'hnp_openmaps_add_plugin_options_page');
// Add settings link to plugin on the Plugins page
function hnp_openmaps_add_settings_link($links) {
$settings_link = '<a href="admin.php?page=hnp-openmaps-osm-settings">' . __('Settings') . '</a>';
array_unshift($links, $settings_link); // Add the settings link at the beginning of the array
return $links;
}
add_filter('plugin_action_links_' . plugin_basename(__FILE__), 'hnp_openmaps_add_settings_link');
// Function to render plugin options page
function hnp_openmaps_render_plugin_options_page() {
?>
<div class="wrap">
<h1>HNP OpenStreetMap Settings</h1>
<form method="post" action="options.php">
<?php settings_fields('hnp_openmaps_osm_settings_group'); ?>
<?php do_settings_sections('hnp-openmaps-osm-settings'); ?>
<?php
// Add nonce
wp_nonce_field('hnp_openmaps_osm_settings_nonce', 'hnp_openmaps_osm_settings_nonce');
?>
<?php submit_button(); ?>
</form>
</div>
<?php
}
</pre>
<pre>
// Function to register plugin options
function hnp_openmaps_register_plugin_options() {
// Adresse
add_settings_section(
'hnp_openmaps_osm_address_section',
'Address',
'hnp_openmaps_osm_address_section_callback',
'hnp-openmaps-osm-settings'
);
add_settings_field(
'hnp_openmaps_map_address',
'Address',
'hnp_openmaps_map_address_callback',
'hnp-openmaps-osm-settings',
'hnp_openmaps_osm_address_section'
);
register_setting('hnp_openmaps_osm_settings_group', 'hnp_openmaps_map_address');
// Name
add_settings_section(
'hnp_openmaps_osm_name_section',
'Name',
'hnp_openmaps_osm_name_section_callback',
'hnp-openmaps-osm-settings'
);
add_settings_field(
'hnp_openmaps_map_name',
'Name',
'hnp_openmaps_map_name_callback',
'hnp-openmaps-osm-settings',
'hnp_openmaps_osm_name_section'
);
register_setting('hnp_openmaps_osm_settings_group', 'hnp_openmaps_map_name');
// Karten-Zoom
add_settings_section(
'hnp_openmaps_osm_zoom_section',
'Map Zoom',
'hnp_openmaps_osm_zoom_section_callback',
'hnp-openmaps-osm-settings'
);
add_settings_field(
'hnp_openmaps_map_zoom',
'Map Zoom',
'hnp_openmaps_map_zoom_callback',
'hnp-openmaps-osm-settings',
'hnp_openmaps_osm_zoom_section'
);
register_setting('hnp_openmaps_osm_settings_group', 'hnp_openmaps_map_zoom');
// Kartenstil
add_settings_section(
'hnp_openmaps_osm_style_section',
'Map Style',
'hnp_openmaps_osm_style_section_callback',
'hnp-openmaps-osm-settings'
);
add_settings_field(
'hnp_openmaps_map_style',
'Map Style',
'hnp_openmaps_map_style_callback',
'hnp-openmaps-osm-settings',
'hnp_openmaps_osm_style_section'
);
register_setting('hnp_openmaps_osm_settings_group', 'hnp_openmaps_map_style');
add_settings_section(
'hnp_openmaps_osm_height_section',
'Map Height',
'hnp_openmaps_osm_height_section_callback',
'hnp-openmaps-osm-settings'
);
add_settings_field(
'hnp_openmaps_map_height',
'Map Height',
'hnp_openmaps_map_height_callback',
'hnp-openmaps-osm-settings',
'hnp_openmaps_osm_height_section'
);
register_setting('hnp_openmaps_osm_settings_group', 'hnp_openmaps_map_height');
add_settings_section(
'hnp_openmaps_osm_width_section',
'Map Width',
'hnp_openmaps_osm_width_section_callback',
'hnp-openmaps-osm-settings'
);
add_settings_field(
'hnp_openmaps_map_width',
'Map Width',
'hnp_openmaps_map_width_callback',
'hnp-openmaps-osm-settings',
'hnp_openmaps_osm_width_section'
);
register_setting('hnp_openmaps_osm_settings_group', 'hnp_openmaps_map_width');
add_settings_section(
'hnp_openmaps_shortcode_section',
'Shortcode',
'hnp_openmaps_shortcode_section_callback',
'hnp-openmaps-osm-settings'
);
}
</pre>
<pre>
// Callback functions for each option
function hnp_openmaps_osm_address_section_callback() {
echo '<p>Enter the address to be displayed on the map. <br>Format: Streetname + Housenumber, City Name + ZIP Code, Country <br>(Separate each part with a comma)</p>';
}
function hnp_openmaps_map_address_callback() {
$address = get_option('hnp_openmaps_map_address', 'Hardenbergpl. 8, 10787 Berlin, Germany');
echo '<input type="text" name="hnp_openmaps_map_address" value="' . esc_attr($address) . '" />';
}
function hnp_openmaps_osm_name_section_callback() {
echo '<p>Enter the name for the marker to be displayed on the map.</p>';
}
function hnp_openmaps_map_name_callback() {
$name = get_option('hnp_openmaps_map_name', 'Berlin Zoological Garden');
echo '<input type="text" name="hnp_openmaps_map_name" value="' . esc_attr($name) . '" />';
}
function hnp_openmaps_osm_zoom_section_callback() {
echo '<p>Set the zoom level of the map.</p>';
}
function hnp_openmaps_map_zoom_callback() {
$zoom = get_option('hnp_openmaps_map_zoom', 12);
echo '<input type="number" name="hnp_openmaps_map_zoom" value="' . esc_attr($zoom) . '" />';
}
function hnp_openmaps_osm_style_section_callback() {
echo '<p>Select the map style.</p>';
}
function hnp_openmaps_map_style_callback() {
$style = get_option('hnp_openmaps_map_style', 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png');
$styles = array(
'Standard (OpenStreetMap)' => 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',
'Hot' => 'https://{s}.tile.openstreetmap.fr/hot/{z}/{x}/{y}.png',
'Cycle' => 'https://tile.thunderforest.com/cycle/{z}/{x}/{y}.png',
'Transport' => 'https://{s}.tile.thunderforest.com/transport/{z}/{x}/{y}.png'
// More styles can be added here
);
echo '<select name="hnp_openmaps_map_style">';
foreach ($styles as $label => $url) {
echo '<option value="' . esc_attr($url) . '" ' . selected($style, $url, false) . '>' . esc_html($label) . '</option>';
}
echo '</select>';
}
function hnp_openmaps_osm_height_section_callback() {
echo '<p>Set the height of the map.</p>';
}
function hnp_openmaps_map_height_callback() {
$height = get_option('hnp_openmaps_map_height', '400px');
echo '<input type="text" name="hnp_openmaps_map_height" value="' . esc_attr($height) . '" />';
}
function hnp_openmaps_osm_width_section_callback() {
echo '<p>Set the width of the map.</p>';
}
function hnp_openmaps_map_width_callback() {
$width = get_option('hnp_openmaps_map_width', '100%');
echo '<input type="text" name="hnp_openmaps_map_width" value="' . esc_attr($width) . '" />';
}
function hnp_openmaps_shortcode_section_callback() {
echo '<p>Shortcode: &#x5B;hnp_openmaps_display_map_with_pin]</p>';
}
// Register plugin options and security measures
add_action('admin_init', 'hnp_openmaps_register_plugin_options');
// Security measures: Nonce verification for options update
function hnp_openmaps_validate_settings($input) {
return $input; // Simply return the input, no further validation here
}
// Security measures: Nonce verification and save options
function hnp_openmaps_register_security_options() {
// Check if the current page is our plugin options page
if (isset($_POST['option_page']) && $_POST['option_page'] == 'hnp_openmaps_osm_settings_group') {
// Check if the nonce is set and valid
if (!isset($_POST['hnp_openmaps_osm_settings_nonce']) || !wp_verify_nonce($_POST['hnp_openmaps_osm_settings_nonce'], 'hnp_openmaps_osm_settings_nonce')) {
// Unauthorized request, do not save options
wp_die('Unauthorized request.'); // Output error message for unauthorized requests
}
// Save options
update_option('hnp_openmaps_map_address', $_POST['hnp_openmaps_map_address']);
update_option('hnp_openmaps_map_name', $_POST['hnp_openmaps_map_name']);
update_option('hnp_openmaps_map_zoom', $_POST['hnp_openmaps_map_zoom']);
update_option('hnp_openmaps_map_style', $_POST['hnp_openmaps_map_style']);
update_option('hnp_openmaps_map_height', $_POST['hnp_openmaps_map_height']);
update_option('hnp_openmaps_map_width', $_POST['hnp_openmaps_map_width']);
}
}
add_action('admin_init', 'hnp_openmaps_register_security_options');
</pre>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/10/hnp-openstreetmap-kostenloses-plugin/">HNP OpenStreetMap kostenloses Plugin</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/04/10/hnp-openstreetmap-kostenloses-plugin/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
</item>
<item>
<title>Dynamische Templates in WordPress erzeugen & einbinden</title>
<link>https://homepage-nach-preis.de/2024/04/07/dynamische-templates-in-wordpress-erzeugen-einbinden/</link>
<comments>https://homepage-nach-preis.de/2024/04/07/dynamische-templates-in-wordpress-erzeugen-einbinden/#respond</comments>
<dc:creator><![CDATA[Homepage-nach-Preis]]></dc:creator>
<pubDate>Sun, 07 Apr 2024 16:20:29 +0000</pubDate>
<category><![CDATA[Webdesign]]></category>
<category><![CDATA[Wordpress Code]]></category>
<category><![CDATA[Dynamische]]></category>
<category><![CDATA[einbinden]]></category>
<category><![CDATA[Funktion]]></category>
<category><![CDATA[Templates]]></category>
<category><![CDATA[wordpress]]></category>
<guid isPermaLink="false">https://homepage-nach-preis.de/?p=8161</guid>
<description><![CDATA[<p>Das “HNP Dyn Template” Plugin ermöglicht es Benutzern, zwischen verschiedenen Vorlagen für eine bestimmte Seite oder einen Beitrag zu wählen. Durch Hinzufügen von Shortcodes können Benutzer auf einfache Weise zwischen verschiedenen Templates hin- und herwechseln, ohne den Code manuell bearbeiten zu müssen. Code-Beschreibung: Shortcodes: Das Plugin fügt zwei Shortcodes hinzu: hnp_template_switcher und hnp_template_switcher_buttons. hnp_template_switcher: Dieser Shortcode rendert den Bereich, in dem das ausgewählte Template dynamisch geladen wird. Es verwendet eine PHP-Include-Anweisung, um die entsprechende Template-Datei zu laden. hnp_template_switcher_buttons: Dieser Shortcode rendert die Schaltflächen, mit denen Benutzer zwischen den verschiedenen Templates wählen können. Es gibt zwei Schaltflächen, um Template 1 und Template 2 zu laden. JavaScript: Das Plugin verwendet JavaScript, um auf Benutzerinteraktionen zu reagieren und die Templates dynamisch zu laden. Es bindet Klickereignisse an die Schaltflächen, um die entsprechenden Templates zu laden. Dazu wird eine XMLHttpRequest verwendet, um die Template-Dateien abzurufen und sie dann in den Container zu rendern. Vorteile und Nutzen: Benutzerfreundlichkeit: Das Plugin macht es einfach, zwischen verschiedenen Vorlagen zu wechseln, ohne dass Benutzer den Code bearbeiten müssen. Durch die Verwendung von Shortcodes können Benutzer die Schaltflächen und den Template-Bereich einfach in ihre Seiten und Beiträge einfügen. Flexibilität: Benutzer können verschiedene Templates erstellen und sie je nach Bedarf....</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/07/dynamische-templates-in-wordpress-erzeugen-einbinden/">Dynamische Templates in WordPress erzeugen & einbinden</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></description>
<content:encoded><![CDATA[<p>Das “HNP Dyn Template” Plugin ermöglicht es Benutzern, zwischen verschiedenen Vorlagen für eine bestimmte Seite oder einen Beitrag zu wählen. Durch Hinzufügen von Shortcodes können Benutzer auf einfache Weise zwischen verschiedenen Templates hin- und herwechseln, ohne den Code manuell bearbeiten zu müssen.</p>
<p><strong>Code-Beschreibung:</strong></p>
<p>Shortcodes: Das Plugin fügt zwei Shortcodes hinzu: hnp_template_switcher und hnp_template_switcher_buttons.</p>
<p>hnp_template_switcher: Dieser Shortcode rendert den Bereich, in dem das ausgewählte Template dynamisch geladen wird. Es verwendet eine PHP-Include-Anweisung, um die entsprechende Template-Datei zu laden.</p>
<p>hnp_template_switcher_buttons: Dieser Shortcode rendert die Schaltflächen, mit denen Benutzer zwischen den verschiedenen Templates wählen können. Es gibt zwei Schaltflächen, um Template 1 und Template 2 zu laden.</p>
<p>JavaScript: Das Plugin verwendet JavaScript, um auf Benutzerinteraktionen zu reagieren und die Templates dynamisch zu laden. Es bindet Klickereignisse an die Schaltflächen, um die entsprechenden Templates zu laden. Dazu wird eine XMLHttpRequest verwendet, um die Template-Dateien abzurufen und sie dann in den Container zu rendern.</p>
<p><strong>Vorteile und Nutzen:</strong></p>
<p>Benutzerfreundlichkeit: Das Plugin macht es einfach, zwischen verschiedenen Vorlagen zu wechseln, ohne dass Benutzer den Code bearbeiten müssen. Durch die Verwendung von Shortcodes können Benutzer die Schaltflächen und den Template-Bereich einfach in ihre Seiten und Beiträge einfügen.</p>
<p>Flexibilität: Benutzer können verschiedene Templates erstellen und sie je nach Bedarf anpassen. Dies ermöglicht es, verschiedene Layouts und Designs für verschiedene Zwecke zu verwenden.</p>
<p>Zeitersparnis: Durch die Verwendung des Plugins können Benutzer Zeit sparen, da sie nicht jedes Mal den Code ändern müssen, wenn sie ein anderes Template verwenden möchten. Stattdessen können sie einfach die entsprechende Schaltfläche anklicken.</p>
<p><strong>Umfang:</strong></p>
<p>Das Plugin umfasst zwei Hauptkomponenten: die Shortcodes für den Template-Switcher und die zugehörige JavaScript-Funktionalität. Die Shortcodes sind einfach zu verwenden und erfordern nur minimale Konfiguration, während das JavaScript für die dynamische Laden der Templates sorgt.</p>
<p><strong>Lizenz:</strong></p>
<p>Das “HNP Dyn Template” Plugin wird unter der GNU General Public License (GPLv3) vertrieben, was bedeutet, dass es frei verwendet, modifiziert und weitergegeben werden kann, solange die Lizenzbedingungen eingehalten werden.</p>
<p><strong>Download:</strong><br />
WordPress Plugin mit Ajax: [sdm_download id=”8168″ fancy=”0″]<br />
WordPress Plugin ohne Ajax: [sdm_download id=”8171″ fancy=”0″]</p>
<p><strong>WordPress Plugin Code ohne Ajax (schnellere Ladezeiten):</strong></p>
<pre><?php
/*
* Plugin Name: HNP Dyn Template
* Plugin URI: https://homepage-nach-preis.de/
* Description: Erstellt 2 Button welche bei Betätigung die Template-Datei auswechseln. Shortcodes: hnp_template_switcher_buttons und hnp_template_switcher
* Version: 1.1
* Author: HNP
* Author URI: https://homepage-nach-preis.de/
* License: GPLv3
*/
// Shortcode für den Template-Switcher hinzufügen
add_shortcode('hnp_template_switcher', 'hnp_custom_template_switcher_shortcode');
// Funktion zum Rendern des Shortcodes
function hnp_custom_template_switcher_shortcode() {
ob_start();
?>
<div id="hnp-template-container">
<!-- Hier wird das Template dynamisch geladen -->
<?php include_once(plugin_dir_path(__FILE__) . '/templates/hnp_template_1.php'); ?>
</div>
<?php
return ob_get_clean();
}
// Shortcode für die Schaltflächen zum Wechseln der Templates hinzufügen
add_shortcode('hnp_template_switcher_buttons', 'hnp_custom_template_switcher_buttons_shortcode');
// Funktion zum Rendern des Shortcodes für die Schaltflächen
function hnp_custom_template_switcher_buttons_shortcode() {
ob_start();
?>
<button id="hnp-template1-btn">Template 1 laden</button>
<button id="hnp-template2-btn">Template 2 laden</button>
<?php
return ob_get_clean();
}
// JavaScript zum Schalten der Templates hinzufügen
add_action('wp_footer', 'hnp_custom_template_switcher_js');
function hnp_custom_template_switcher_js() {
?>
<script>
document.addEventListener('DOMContentLoaded', function() {
document.getElementById('hnp-template1-btn').addEventListener('click', function() {
loadTemplate('hnp_template_1.php');
});
document.getElementById('hnp-template2-btn').addEventListener('click', function() {
loadTemplate('hnp_template_2.php');
});
});
function loadTemplate(templateUrl) {
var xhr = new XMLHttpRequest();
xhr.open('GET', '<?php echo plugins_url("templates/", __FILE__); ?>' + templateUrl, true);
xhr.onreadystatechange = function() {
if (xhr.readyState === 4 && xhr.status === 200) {
document.getElementById('hnp-template-container').innerHTML = xhr.responseText;
}
};
xhr.send();
}
</script>
<?php
}
</pre>
<p><strong>Template 1 Datei:</strong></p>
<pre><?php
/*
Template Name: Template 1
*/
?>
<div class="hnp-template-content">
<h2>Template 1</h2>
<p>Dies ist der Inhalt von Template 1.</p>
</div>
</pre>
<p><strong>Template 2 Datei:</strong></p>
<pre><?php
/*
Template Name: Template 2
*/
?>
<div class="hnp-template-content">
<h2>Template 2</h2>
<p>Dies ist der Inhalt von Template 2.</p>
</div>
</pre>
<p><strong>WordPress Plugin Code mit Ajax:</strong></p>
<pre><?php
/*
* Plugin Name: HNP Dyn Template
* Plugin URI: https://homepage-nach-preis.de/
* Description: Erstellt 2 Button welche bei Betätigung die Template-Datei auswechseln. Shortcodes: hnp_template_switcher_buttons und hnp_template_switcher
* Version: 1.1
* Author: HNP
* Author URI: https://homepage-nach-preis.de/
* License: HNP-Dyn-Template
*/
// Shortcode für den Template-Switcher hinzufügen
add_shortcode('hnp_template_switcher', 'hnp_custom_template_switcher_shortcode');
// Funktion zum Rendern des Shortcodes
function hnp_custom_template_switcher_shortcode() {
ob_start();
?>
<div id="hnp-template-container">
<!-- Hier wird das Template dynamisch geladen -->
<?php include_once(plugin_dir_path(__FILE__) . '/templates/hnp_template_1.php'); ?>
</div>
<?php
return ob_get_clean();
}
// Shortcode für die Schaltflächen zum Wechseln der Templates hinzufügen
add_shortcode('hnp_template_switcher_buttons', 'hnp_custom_template_switcher_buttons_shortcode');
// Funktion zum Rendern des Shortcodes für die Schaltflächen
function hnp_custom_template_switcher_buttons_shortcode() {
ob_start();
?>
<button id="hnp-template1-btn">Template 1 laden</button>
<button id="hnp-template2-btn">Template 2 laden</button>
<?php
return ob_get_clean();
}
// JavaScript zum Schalten der Templates hinzufügen
add_action('wp_footer', 'hnp_custom_template_switcher_js');
function hnp_custom_template_switcher_js() {
wp_enqueue_script('hnp-custom-template-switcher', plugin_dir_url(__FILE__) . 'hnp_dyn_template.js', array('jquery'), null, true);
wp_localize_script('hnp-custom-template-switcher', 'hnpTemplateSwitcher', array(
'ajaxurl' => admin_url('admin-ajax.php')
));
}
// Ajax
add_action('wp_ajax_load_template', 'hnp_load_template_ajax');
add_action('wp_ajax_nopriv_load_template', 'hnp_load_template_ajax');
function hnp_load_template_ajax() {
$template = isset($_GET['template']) ? $_GET['template'] : '';
if ($template) {
// Hier können Sie die Template-Datei laden und den Inhalt zurückgeben
include(plugin_dir_path(__FILE__) . '/templates/' . $template);
}
wp_die();
}
</pre>
<p><strong>Javascript:</strong></p>
<pre>document.addEventListener('DOMContentLoaded', function() {
document.getElementById('hnp-template1-btn').addEventListener('click', function() {
loadTemplate('hnp_template_1.php');
});
document.getElementById('hnp-template2-btn').addEventListener('click', function() {
loadTemplate('hnp_template_2.php');
});
});
function loadTemplate(templateUrl) {
var xhr = new XMLHttpRequest();
xhr.open('GET', hnpTemplateSwitcher.ajaxurl + '?action=load_template&template=' + templateUrl, true);
xhr.onreadystatechange = function() {
if (xhr.readyState === 4 && xhr.status === 200) {
document.getElementById('hnp-template-container').innerHTML = xhr.responseText;
}
};
xhr.send();
}
</pre>
<p>Template Dateien hierbei identisch.</p>
<p>Der Beitrag <a rel="nofollow" href="https://homepage-nach-preis.de/2024/04/07/dynamische-templates-in-wordpress-erzeugen-einbinden/">Dynamische Templates in WordPress erzeugen & einbinden</a> erschien zuerst auf <a rel="nofollow" href="https://homepage-nach-preis.de">Homepage nach Preis - Webseite erstellen lassen</a>. Geschrieben von <a rel="nofollow" href="https://homepage-nach-preis.de/author/homepageadmin/">Homepage-nach-Preis</a>.</p>
]]></content:encoded>
<wfw:commentRss>https://homepage-nach-preis.de/2024/04/07/dynamische-templates-in-wordpress-erzeugen-einbinden/feed/</wfw:commentRss>
<slash:comments>0</slash:comments>
</item>
</channel>
</rss>
If you would like to create a banner that links to this page (i.e. this validation result), do the following:
Download the "valid RSS" banner.
Upload the image to your own server. (This step is important. Please do not link directly to the image on this server.)
Add this HTML to your page (change the image src
attribute if necessary):
If you would like to create a text link instead, here is the URL you can use:
http://www.feedvalidator.org/check.cgi?url=https%3A//homepage-nach-preis.de/feed/