Si vous souhaitez configurer la passerelle de paiement Bkash, vous devez suivre quelques étapes. Ci-dessous, je donne un guide étape par étape sur la façon dont vous pouvez intégrer la passerelle de paiement Bkash. Pour cela, nous utiliserons l'API marchand de Bkash.
1. Éléments essentiels pour l'intégration de l'API Bkash
Compte marchand Bkash : vous devez disposer d'un compte marchand Bkash. Sinon, vous pouvez postuler pour Bkash Merchant.
Informations d'identification API : Bkash vous fournira le nom d'utilisateur API, le mot de passe API, la clé d'application et le secret d'application après la configuration du compte marchand.
Certificat SSL : Un certificat SSL est obligatoire pour la passerelle de paiement Bkash.
URL Webhook : vous devez définir une URL Webhook pour recevoir des notifications de paiement.
2. Processus d'intégration de la passerelle de paiement
Étape 1 : Configuration de l'environnement
Configurez d’abord votre environnement PHP ou tout autre environnement côté serveur.
Fichier composer.json (si vous utilisez PHP)
json
Copier le code
{
"exiger": {
"guzzlehttp/guzzle": "^7.0"
>
>
Ensuite, exécutez composer install.
ধাপ ২ : ফাইল এবং ডিরেক্টরি স্ট্রাকচার
texte en clair
Copier le code
racine du projet/
├── index.php
├──bkash/
│ ├── config.php
│ ├── jeton.php
│ ├── create_payment.php
│ ├──execute_payment.php
│ └── query_payment.php
└── success.php
Lire : Configuration de l'API Bkash (bkash/config.php)
php
Copier le code
revenir [
'base_url' => 'https://checkout.sandbox.bka.sh/v1.2.0-beta',
'nom d'utilisateur' => 'VOTRE_BKASH_USERNAME',
'mot de passe' => 'VOTRE_BKASH_PASSWORD',
'app_key' => 'VOTRE_APP_KEY',
'app_secret' => 'VOTRE_APP_SECRET',
'callback_url' => 'https://fqrhost.com/success.php'
];
?>
ধাপ ৪ : Générer un jeton d'accès (bkash/token.php)
php
Copier le code
$config = include('config.php');
fonction generateToken() {
global $config;
$url = $config['base_url'] . '/checkout/token/grant';
$en-têtes = [
'Type de contenu :application/json',
'nom d'utilisateur:' . $config['nom d'utilisateur'],
'mot de passe:' . $config['mot de passe']
];
$data = [ 'app_key' => $config['app_key'], 'app_secret' => $config['app_secret'] ]; $curl = curl_init($url); curl_setopt($curl, CURLOPT_HTTPHEADER, $headers); curl_setopt($curl, CURLOPT_POST, true); curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data)); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); $result = curl_exec($curl); curl_close($curl); $response = json_decode($result, true); return $response['id_token'];
}
$token = generateToken();
?>
ধাপ ৫ : Créer un paiement (bkash/create_payment.php)
php
Copier le code
include('token.php');
fonction createPayment($montant) {
global $config, $token;
$url = $config['base_url'] . '/checkout/paiement/créer';
$en-têtes = [
'Type de contenu :application/json',
'autorisation :' . $jeton,
'x-app-key :' . $config['app_key']
];
$data = [ 'amount' => $amount, 'currency' => 'BDT', 'intent' => 'sale', 'merchantInvoiceNumber' => 'INV-' . uniqid(), 'callbackURL' => $config['callback_url'] ]; $curl = curl_init($url); curl_setopt($curl, CURLOPT_HTTPHEADER, $headers); curl_setopt($curl, CURLOPT_POST, true); curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data)); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); $result = curl_exec($curl); curl_close($curl); return json_decode($result, true);
}
$response = createPayment(1000); // ১০০০ টাকা পেমেন্ট
header('Emplacement : ' . $response['bkashURL']);
?>
ধাপ ৬ : Exécuter le paiement (bkash/execute_payment.php)
php
Copier le code
include('token.php');
fonction exécuterPayment($paymentID) {
global $config, $token;
$url = $config['base_url'] . '/checkout/paiement/exécuter/' . $ID de paiement ;
$en-têtes = [
'Type de contenu :application/json',
'autorisation :' . $jeton,
'x-app-key :' . $config['app_key']
];
$curl = curl_init($url); curl_setopt($curl, CURLOPT_HTTPHEADER, $headers); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); $result = curl_exec($curl); curl_close($curl); return json_decode($result, true);
}
if (isset($_GET['paymentID'])) {
$response = exécuterPayment($_GET['paymentID']);
écho '
$data = [ 'app_key' => $config['app_key'], 'app_secret' => $config['app_secret'] ]; $curl = curl_init($url); curl_setopt($curl, CURLOPT_HTTPHEADER, $headers); curl_setopt($curl, CURLOPT_POST, true); curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($data)); curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); $result = curl_exec($curl); curl_close($curl); $response = json_decode($result, true); return $response['id_token'];';
>
?>
Étape 7 : Page de réussite (success.php)
php
Copier le code
echo "Paiement réussi!";
?>
3. Tests du système
Vous pouvez tester votre système à l'aide de l'environnement Sandbox de Bkash.
Pour utiliser le mode production, mettez à jour votre clé API et votre URL depuis Bkash.
4. Configuration du webhook (facultatif)
Bkash peut utiliser l'URL du Webhook pour les mises à jour de paiement. Une notification vous sera envoyée avec les informations de paiement.
acheter un hébergement de domaine
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

PhpSessionsCanstorestrings, Numbers, Arrays, Andobject.1.Strings: TextDatalikeUserames.2.Numbers: IntegersorFloatsForCounters.3.arrays: listslikeshoppingcarts.4.Objects: complexestructuresthataReSerialized.

TostartaphpSession, usessession_start () aTTheScript'sbeginning.1) PlaceItBeForeanyOutputToSetTheSessionCooKie.2) USESSIONSFORUSERDATALIKELOGINSTATUSORSHOPPINGSCARS.3) RegegeraSesessionIdStopreventfixationAtTACKS.4)

La régénération de session fait référence à la génération d'un nouvel ID de session et à l'invalidation de l'ancien ID lorsque l'utilisateur effectue des opérations sensibles en cas d'attaques fixes de session. Les étapes de mise en œuvre incluent: 1. Détectez les opérations sensibles, 2. Générer un nouvel ID de session, 3. Détruiser l'ancien ID de session, 4. Mettre à jour les informations de session côté utilisateur.

Les séances PHP ont un impact significatif sur les performances des applications. Les méthodes d'optimisation incluent: 1. Utilisez une base de données pour stocker les données de session pour améliorer la vitesse de réponse; 2. Réduire l'utilisation des données de session et stocker uniquement les informations nécessaires; 3. Utilisez un processeur de session non bloquant pour améliorer les capacités de concurrence; 4. Ajustez le temps d'expiration de la session pour équilibrer l'expérience utilisateur et la charge du serveur; 5. Utilisez des séances persistantes pour réduire le nombre de données de lecture et d'écriture.

PhpsessionsareServer-côté, whileCookiesareclient-Side.1) SessionStoredataontheServer, aremoresecure, ethandleLargerData.2) CookiesstoredataontheClient, ArelessSecure, andlimitedIzeSize.USESESSIONSFORSENSEDATAANDCOOKIESFORNONNORNE-SENSENSITION, Client-Sidedata.

Phpidentifiesauser'sessionusingssse cookiesand sessionids.1) whenSession_start () est calculé, phpgeneratesauquesseSessionIdStoredInacookIenameDPhpSesssIdonUser'sbrowser.2) thisIdallowsphptoreTrrieSeSessionDatafromTeserver.

La sécurité des sessions PHP peut être obtenue grâce aux mesures suivantes: 1. Utilisez Session_RegeReate_ID () pour régénérer l'ID de session lorsque l'utilisateur se connecte ou est une opération importante. 2. Cryptez l'ID de session de transmission via le protocole HTTPS. 3. Utilisez session_save_path () pour spécifier le répertoire sécurisé pour stocker les données de session et définir correctement les autorisations.

PhpSessionFilesArestorentheDirectorySpecifiedSession.save_path, généralement / tmponunix-likesystemsorc: \ windows \ temponwindows.tocustomzethis: 1) usession_save_path () tosetacustomDirectory, astumeit'swrit


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Listes Sec
SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

DVWA
Damn Vulnerable Web App (DVWA) est une application Web PHP/MySQL très vulnérable. Ses principaux objectifs sont d'aider les professionnels de la sécurité à tester leurs compétences et leurs outils dans un environnement juridique, d'aider les développeurs Web à mieux comprendre le processus de sécurisation des applications Web et d'aider les enseignants/étudiants à enseigner/apprendre dans un environnement de classe. Application Web sécurité. L'objectif de DVWA est de mettre en pratique certaines des vulnérabilités Web les plus courantes via une interface simple et directe, avec différents degrés de difficulté. Veuillez noter que ce logiciel

Dreamweaver CS6
Outils de développement Web visuel

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.
