gpt4 book ai didi

sql-injection - 在模型中使用 sql 时如何防止 Phalcon PHP 中的 SQL 注入(inject)?

转载 作者:行者123 更新时间:2023-12-04 07:38:37 24 4
gpt4 key购买 nike

假设我正在构建一个搜索,以查找所有教师并获得用户可以输入搜索词的输入。我试着阅读 phalcon 文档,但我只看到绑定(bind)参数之类的东西。我阅读了另一个关于需要准备语句的线程,我是否也需要在 Phalcon 中使用它?

我在模型中的函数是这样的:

public function findTeachers($q, $userId, $isUser, $page, $limit, $sort)
{
$sql = 'SELECT id FROM tags WHERE name LIKE "%' . $q . '%"';
$result = new Resultset(null, $this,
$this->getReadConnection()->query($sql, array()));
$tagResult = $result->toArray();
$tagList = array();
foreach ($tagResult as $key => $value) {
$tagList[] = $value['id'];
....

}
}

我的问题是关于 Phalcon 框架是否有任何我应该为这一行编写代码的设置或格式 $sql = 'SELECT id FROM tags WHERE name LIKE "%' . $q . '%"';

还有任何关于防止 PhalconPHP Controller 和索引中的 SQL 注入(inject)的一般建议将不胜感激。

供引用:

我的 Controller :

public function searchAction()
{
$this->view->disable();
$q = $this->request->get("q");
$sort = $this->request->get("sort");
$searchUserModel = new SearchUsers();
$loginUser = $this->component->user->getSessionUser();
if (!$loginUser) {
$loginUser = new stdClass;
$loginUser->id = '';
}
$page = $this->request->get("page");
$limit = 2;
if (!$page){
$page = 1;
}

$list = $searchUserModel->findTeachers($q, $loginUser->id, ($loginUser->id)?true:false, $page, $limit, $sort);

if ($list){
$list['status'] = true;
}
echo json_encode($list);
}

我的 Ajax:

function(cb){
$.ajax({
url: '/search/search?q=' + mapObject.q + '&sort=<?php echo $sort;?>' + '&page=' + mapObject.page,
data:{},
success: function(res) {
//console.log(res);
var result = JSON.parse(res);
if (!result.status){
return cb(null, result.list);
}else{
return cb(null, []);
}
},
error: function(xhr, ajaxOptions, thrownError) {
cb(null, []);
}
});

q 是用户的搜索词。

最佳答案

您应该绑定(bind)查询参数以避免 SQL 注入(inject)。据我所知,Phalcon 将“%”通配符放在 conditions 值中可能有点有趣,所以我将它们放在 bind 中。

这比仅仅过滤查询要好。

$tags = Tags::find([
'conditions' => 'name LIKE :name:',
'bind' => [
'name' => "%" . $q . "%"
]
])

关于sql-injection - 在模型中使用 sql 时如何防止 Phalcon PHP 中的 SQL 注入(inject)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31236274/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com