Ecshop、Discuz! 等开源产品的局限,ecshopdiscuz
Ecshop、Discuz! 等开源产品的局限,ecshopdiscuz
记得今年年初,我初次接触Discuz!和Ecshop时,一阵阵地惊叹:成熟度这么高的产品,居然是免费的。我们这些搞传统软件开发的要怎么活?另外也奇怪,做这些产品的公司,他们要怎么活?
我公司的网站,原型正好是用Ecshop和Discuz!,到开发方移交给我们后,我们做二次开发,深入了解了其代码,早期的疑惑才有了答案。
可以说,这些产品,都无法支持真正严肃的应用环境。
1)所有的数据库访问都不用mysqli连接,因此无法用prepared statement,而全部用拼接方式。
这些系统,对数据库(主要都是mysql)的访问,全部采用sql拼接方式。举一个Ecshop的例子:
<span>$w_openid</span> = <span>$db</span> -> getOne("SELECT `wxid` FROM `wxch_user` WHERE `wxid` = '<span>$openid</span>'");
或类似
<span>$wxch_user_sql</span> = "INSERT INTO `<span>$thistable</span>` ( `user_name`,`password`,`field3`,`field4`) VALUES ('$variable1','<span>$variable2</span>','value3','value4')"<span>; </span><span>$db</span> -> query(<span>$wxch_user_sql</span>);
这种语句,偶尔出现倒也可以理解,如果所有的地方都是这样(正如Ecshop),则应该出于对数据库只有入门水平的人手里。因为他完全没有使用prepared statement的概念。
所以,这种系统几个人用应该是快如闪电,并发量一大,后台数据库可能被搅成一锅粥了。
正确的连接数据库的方法应该是:
<span>$mysqli</span> = <span>new</span> mysqli("server", "username", "password", "database_name");
而不是
$conn = mysql_connect('server','username','password') or die ("数据连接错误!!!");
正确的sql语句应该是:
<span>$stmt</span> = <span>$mysqli</span>->prepare("INSERT INTO table (column) VALUES (?)"<span>); </span><span>$stmt</span>->bind_param("s", <span>$safe_variable</span><span>); </span><span>$stmt</span>->execute();
而不是前面那样。
2)系统安全性极差
因为不用prepared statement,只要编程人员不注意,sql injection可以说到处都有可能。但看看他们的代码,可以说压根不注意。因为这些系统,对用户输入几乎不用转义。
对于已经很烂的代码,正确的用法是应该有第二行:
<span>$unsafe_variable</span> = <span>$_POST</span>["user-input"<span>]; </span><span>$safe_variable</span> = <span>mysql_real_escape_string</span>(<span>$unsafe_variable</span><span>); </span><span>mysql_query</span>("INSERT INTO table (column) VALUES ('" . <span>$safe_variable</span> . "')");
但在这些系统里,上面的第二行很少看到。
这样造成的问题就是,针对这些系统的机器人极多。基本上你的论坛上线不久很快就被机器人发的水贴、广告贴盯上了。
本人对这些系统研究还很肤浅,不过看到这两条,就已经明白,这种系统是供学习用的。开发这些产品的公司,他们的水平很高,不过高质量的代码应该是用在了商业性收费的产品上。大家别以为可以捡到便宜。
转载请注明出处:cnblogs上的海边的骆驼博客。原博文地址:http://www.cnblogs.com/yingjiang/p/4750408.html

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Cara menulis resume pengaturcara PHP yang sempurna Dalam pasaran kerja yang sangat kompetitif, resume yang cemerlang adalah penting untuk pencari kerja. Bagi pengaturcara PHP, menulis resume yang sempurna amat penting, kerana resume bukan sahaja tingkap untuk mempamerkan kemahiran dan pengalaman anda, tetapi juga kunci untuk menarik perhatian majikan. Artikel ini akan menerangkan secara terperinci cara menulis resume kerja pengaturcara PHP yang sempurna dari awal hingga akhir. Langkah Pertama: Pilih Templat Resume Ringkas dan Menarik Memilih templat resume yang ringkas dan menarik adalah langkah pertama dalam menulis resume anda.

Tingkatkan kadar kejayaan pencarian pekerjaan: Petua untuk menulis resume kerja pengaturcara PHP yang cemerlang Dalam masyarakat moden, pencarian pekerjaan telah menjadi tugas penting yang dihadapi oleh setiap graduan. Apabila ia datang untuk memohon pekerjaan, resume anda adalah bahagian yang paling penting. Resume yang cemerlang boleh memenangi temu duga dan juga menentukan sama ada anda boleh berjaya mendapatkan pekerjaan. Terutama untuk jawatan yang sangat kompetitif seperti pengaturcara PHP, cara menulis resume yang cemerlang telah menjadi isu utama bagi setiap pencari kerja. Di bawah ini saya akan berkongsi beberapa petua untuk menulis resume kerja programmer PHP yang sangat baik.

Cara menulis resume pengaturcara PHP yang akan menarik perhatian majikan Dalam pasaran kerja yang sangat kompetitif, adalah penting untuk menulis resume yang cemerlang. Sebagai pengaturcara PHP, sebagai tambahan kepada pengalaman kerja dan kemahiran anda yang mengagumkan, resume juga perlu menggambarkan kecintaan anda terhadap pengaturcaraan dan pengetahuan profesional yang mantap. Artikel ini akan memperkenalkan beberapa petua dan contoh kod untuk membantu anda menulis resume pengaturcara PHP yang akan bersinar di mata majikan. Maklumat peribadi yang ringkas dan jelas Bahagian maklumat peribadi resume anda hendaklah mengandungi nama, maklumat hubungan dan laman web peribadi anda

Petua resume yang menarik untuk pengaturcara PHP: Bagaimana untuk menonjol daripada calon lain Dengan perkembangan pesat industri Internet, pengaturcara PHP juga telah menjadi salah satu jawatan popular dalam pasaran kerja. Walau bagaimanapun, semakin ramai orang memilih PHP sebagai hala tuju pembangunan kerjaya mereka, yang menjadikan persaingan lebih sengit. Dalam keadaan sedemikian, bagaimana untuk menjadikan resume anda menonjol dan menjadi popular di mata majikan adalah persoalan yang perlu difikirkan oleh setiap pengaturcara PHP. Pertama, resume yang baik harus menunjukkan kemahiran anda dengan jelas dan ringkas.

Jalan menuju serangan balas bergaji tinggi untuk pengaturcara PHP Dengan perkembangan pesat Internet, permintaan dalam bidang sains komputer terus meningkat. Pada era ini, orang yang memerlukan kemahiran pengaturcaraan adalah yang paling diminati. Sebagai bahasa pengaturcaraan yang biasa digunakan, PHP menyediakan pengaturcara dengan laluan serangan balas bergaji tinggi. Artikel ini akan memperkenalkan cara pengaturcara PHP boleh bergerak ke arah serangan balas bergaji tinggi dengan mempelajari PHP dan teknologi yang berkaitan, dan melampirkan beberapa contoh kod. 1. Kuasai pengetahuan asas PHP Untuk menjadi pengaturcara PHP yang cemerlang, anda perlu menguasai pengetahuan asas PHP terlebih dahulu.

Jangan diabaikan lagi! Ketahui Cara Mereka Bentuk Resume Pengaturcara PHP yang Mengesankan Dalam pasaran kerja yang kompetitif hari ini, mempunyai resume yang mengagumkan adalah kunci untuk mendapatkan pekerjaan impian anda. Terutama untuk jawatan teknikal seperti pengaturcara PHP, resume adalah tetingkap untuk mempamerkan kemahiran dan pengalaman anda. Artikel ini akan mengajar anda cara mereka bentuk resume pengaturcara PHP yang mengagumkan, lengkap dengan contoh kod. Pertama, resume yang baik akan menarik perhatian pembaca. Tajuk itu hendaklah menggambarkan anda dengan ringkas

Terokai Petua Menulis: Cara Menulis Resume Pengaturcara PHP yang Menarik Dalam pasaran kerja yang kompetitif hari ini, resume yang menarik amat penting untuk pengaturcara PHP. Resume yang baik bukan sahaja menarik perhatian majikan tetapi juga mempamerkan kemahiran dan pengalaman anda. Artikel ini akan meneroka beberapa petua penulisan untuk membantu anda membuat resume pengaturcara PHP yang hebat, lengkap dengan contoh kod yang menyerlahkan kebolehan profesional anda. Format Ringkas dan Jelas Format resume anda hendaklah ringkas dan jelas, membolehkan majikan mengimbas maklumat berkaitan anda dengan cepat.

Dalam pasaran kerja yang sangat kompetitif hari ini, cara untuk menonjolkan diri daripada kumpulan pencari kerja telah menjadi isu yang sangat penting. Khususnya untuk pengaturcara PHP, resume yang baik secara langsung boleh mempengaruhi sama ada anda boleh mendapatkan temu duga. Artikel ini akan memberi anda pengenalan terperinci tentang cara menulis resume pengaturcara PHP yang membuat anda menonjol. Pertama sekali, resume yang baik harus mengandungi bahagian penting berikut: maklumat peribadi, niat kerja, latar belakang pendidikan, pengalaman kerja, kemahiran dan kepakaran, dan pengalaman projek peribadi. Kami akan pergi bahagian demi bahagian
