cari
Rumahpembangunan bahagian belakangmasalah PHPBagaimana untuk melaksanakan fungsi tambah rakan dalam php

Dalam beberapa tahun kebelakangan ini, rangkaian sosial telah menjadi sebahagian daripada kehidupan seharian orang ramai. Pada masa yang sama, hubungan rakan, sebagai bahagian penting dalam rangkaian sosial, juga telah mendapat perhatian yang lebih dalam pelaksanaannya. Artikel ini akan memperkenalkan cara menggunakan PHP untuk melaksanakan fungsi menambah rakan.

1. Reka bentuk pangkalan data

Dalam proses melaksanakan fungsi menambah rakan, jadual perhubungan rakan perlu direka bentuk. Jadual hendaklah mengandungi sekurang-kurangnya medan berikut:

  1. friend_id: ID unik jadual perhubungan rakan
  2. user_id1: ID pengguna pihak perhubungan rakan 1
  3. user_id2: perhubungan rakan ID Pengguna Pihak 2
  4. status: Status perhubungan rakan, nilai pilihan termasuk "1" (sudah menjadi rakan), "0" (tertunda) dan "-1" ( ditolak), dsb.

2. Menambah rakan

Apabila menambah rakan dalam PHP, anda perlu melalui langkah berikut:

  1. Sahkan sama ada ID yang dimasukkan oleh pengguna wujud dalam Dalam pangkalan data;
  2. Semak sama ada rakan yang akan ditambah adalah rakan pengguna
  3. Jika tiada hubungan rakan antara kedua-dua pengguna, tambahkan rekod hubungan rakan baharu dengan; status " 0" (pending);
  4. Jika kedua-dua pengguna itu sudah berkawan, tiada operasi akan dilakukan.

Berikut ialah contoh kod PHP mudah untuk melaksanakan fungsi menambah rakan:

<?php // 连接数据库
$con = mysqli_connect("localhost","root","mypassword","mydatabase");

// 获取用户输入
$user_id1 = $_POST[&#39;user_id1&#39;];
$user_id2 = $_POST[&#39;user_id2&#39;];

// 验证用户输入是否合法
if(!is_numeric($user_id1) || !is_numeric($user_id2)) {
    echo "Error: 用户ID必须为数字";
    exit();
}

// 检查要添加的好友是否已经是用户的好友
$sql = "SELECT * FROM friend_relation WHERE ((user_id1 = $user_id1 AND user_id2 = $user_id2) OR (user_id2 = $user_id1 AND user_id1 = $user_id2)) AND status = 1";
$result = mysqli_query($con,$sql);

if(mysqli_num_rows($result) > 0) {
    echo "该用户已经是您的好友!";
    exit();
}

// 如果两个用户之间没有好友关系,则添加一条新的好友关系记录,其中状态为“0”(待处理)
$sql = "INSERT INTO friend_relation (user_id1,user_id2,status) VALUES ($user_id1,$user_id2,0)";
if(mysqli_query($con,$sql)) {
    echo "添加好友请求已经发送!";
} else {
    echo "Error: " . mysqli_error($con);
}

mysqli_close($con);
?>

Dalam kod di atas, kami menggunakan sambungan mysqli untuk menyambung ke pangkalan data MySQL . ID kedua-dua pengguna diperoleh melalui kaedah POST, dan kemudian pengesahan input dan semakan perhubungan rakan dilakukan. Jika rakan yang akan ditambah sudah menjadi rakan pengguna, mesej segera akan dikeluarkan jika tiada hubungan rakan antara kedua-dua pengguna, rekod hubungan rakan baharu ditambahkan pada pangkalan data, dan mesej gesaan kejayaan dikeluarkan.

3. Pemprosesan permintaan rakan

Dalam fungsi menambah rakan, ia juga perlu untuk melaksanakan pemprosesan permintaan rakan. Apabila pengguna menghantar permintaan rakan kepada pengguna lain, pengguna yang diminta perlu melakukan pemprosesan yang sepadan, termasuk menerima atau menolak permintaan tersebut.

Dalam reka bentuk pangkalan data, kami menetapkan status hubungan rakan (status) kepada "0" untuk menunjukkan bahawa permintaan rakan belum diproses, kepada "1" untuk menunjukkan bahawa rakan itu sudah menjadi rakan, dan kepada "-1" untuk menunjukkan bahawa rakan itu Permintaan telah ditolak. Oleh itu, dalam fungsi pemprosesan permintaan rakan, kita perlu menambah kod kemas kini status yang sepadan.

Berikut ialah contoh kod PHP mudah untuk memproses permintaan rakan:

<?php // 连接数据库
$con = mysqli_connect("localhost","root","mypassword","mydatabase");

// 获取用户输入
$user_id1 = $_POST[&#39;user_id1&#39;];
$user_id2 = $_POST[&#39;user_id2&#39;];
$action = $_POST[&#39;action&#39;]; // 操作类型,可选值包括“accept”和“reject”

// 验证用户输入是否合法
if(!is_numeric($user_id1) || !is_numeric($user_id2)) {
    echo "Error: 用户ID必须为数字";
    exit();
}

// 更新好友关系状态
if($action == "accept") {
    $sql = "UPDATE friend_relation SET status = 1 WHERE user_id1 = $user_id1 AND user_id2 = $user_id2";
    if(mysqli_query($con,$sql)) {
        echo "您已经同意该好友请求!";
    } else {
        echo "Error: " . mysqli_error($con);
    }
} else if($action == "reject") {
    $sql = "UPDATE friend_relation SET status = -1 WHERE user_id1 = $user_id1 AND user_id2 = $user_id2";
    if(mysqli_query($con,$sql)) {
        echo "您已经拒绝了该好友请求!";
    } else {
        echo "Error: " . mysqli_error($con);
    }
} else {
    echo "Error: 请输入正确的操作类型!";
}

mysqli_close($con);
?>

Dalam kod di atas, kami memperoleh ID dan operasi dua pengguna melalui kaedah POST Type, "accept " bermaksud menerima permintaan rakan, "tolak" bermaksud menolak permintaan rakan. Kemudian, kami mengemas kini status perhubungan rakan melalui kenyataan KEMASKINI dan mengeluarkan maklumat segera yang sepadan.

Dengan contoh kod PHP di atas, kami boleh melaksanakan fungsi menambah rakan dan memproses permintaan rakan dengan mudah. Dalam pembangunan sebenar, ia boleh diubah suai dengan sewajarnya mengikut keperluan khusus dan dioptimumkan dari segi keselamatan dan prestasi.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi tambah rakan dalam php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Asid vs pangkalan data asas: perbezaan dan bila menggunakan setiap.Asid vs pangkalan data asas: perbezaan dan bila menggunakan setiap.Mar 26, 2025 pm 04:19 PM

Artikel ini membandingkan model pangkalan data asid dan asas, memperincikan ciri -ciri mereka dan kes penggunaan yang sesuai. Asid mengutamakan integriti data dan konsistensi, sesuai untuk aplikasi kewangan dan e-dagang, sementara asas memberi tumpuan kepada ketersediaan dan

PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail.PHP Secure File Muat naik: Mencegah kelemahan berkaitan fail.Mar 26, 2025 pm 04:18 PM

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

Pengesahan Input PHP: Amalan Terbaik.Pengesahan Input PHP: Amalan Terbaik.Mar 26, 2025 pm 04:17 PM

Artikel membincangkan amalan terbaik untuk pengesahan input PHP untuk meningkatkan keselamatan, memberi tumpuan kepada teknik seperti menggunakan fungsi terbina dalam, pendekatan putih, dan pengesahan sisi pelayan.

PHP API Kadar Mengehadkan: Strategi Pelaksanaan.PHP API Kadar Mengehadkan: Strategi Pelaksanaan.Mar 26, 2025 pm 04:16 PM

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan

PHP Kata Laluan Hashing: password_hash dan password_verify.PHP Kata Laluan Hashing: password_hash dan password_verify.Mar 26, 2025 pm 04:15 PM

Artikel ini membincangkan manfaat menggunakan password_hash dan password_verify dalam php untuk mendapatkan kata laluan. Hujah utama ialah fungsi ini meningkatkan perlindungan kata laluan melalui penjanaan garam automatik, algoritma hashing yang kuat, dan secur

OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum.OWASP Top 10 PHP: Huraikan dan mengurangkan kelemahan umum.Mar 26, 2025 pm 04:13 PM

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

Pencegahan PHP XSS: Bagaimana Melindungi Terhadap XSS.Pencegahan PHP XSS: Bagaimana Melindungi Terhadap XSS.Mar 26, 2025 pm 04:12 PM

Artikel ini membincangkan strategi untuk mencegah serangan XSS di PHP, memberi tumpuan kepada sanitisasi input, pengekodan output, dan menggunakan perpustakaan dan kerangka kerja yang meningkatkan keselamatan.

PHP Interface vs Kelas Abstrak: Bila Menggunakan Setiap.PHP Interface vs Kelas Abstrak: Bila Menggunakan Setiap.Mar 26, 2025 pm 04:11 PM

Artikel ini membincangkan penggunaan antara muka dan kelas abstrak dalam PHP, memberi tumpuan kepada masa untuk menggunakan setiap. Antara muka menentukan kontrak tanpa pelaksanaan, sesuai untuk kelas yang tidak berkaitan dan warisan berganda. Kelas Abstrak Memberi Funct Biasa

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!