douruyun8153 2013-11-19 11:17
浏览 160
已采纳

Laravel - 在where子句列中使用mysql函数

I have a database with encrypted field using AES_ENCRYPT

the data is encrypted and should stay this way, so there is no way of changing the method it is encrypted with.

Recently I started working on a new project with Laravel. when I tried to do an update with a where clause on the field encrypted with AES, I received the following query:

SELECT * FROM `users` WHERE `mail` = ? LIMIT 1

And the following binding:

AES_ENCRYPT('email@email.com', 'somekey')

For the following code:

$email = Input::get('email');
$user = User::where("mail", "AES_ENCRYPT('{$email}', '{$this->aesKey}')")->first();

Which is basically logical - But how do I use force it do the following Query:

SELECT * FROM `users` WHERE `mail` = AES_ENCRYPT(?, 'someKey') limit 1

With this binding:

email@email.com

Hope there is a way passing function to the where clause on the value

  • 写回答

3条回答 默认 最新

  • dpx49470 2016-03-09 16:23
    关注

    In laravel 5 you can use whereRaw with bindings too, so you get correct escaping and injection prevention.

    Just pass bindings array as second parameter. For example:

    $user = User::where("mail = AES_ENCRYPT(:email, :aesKey)", ['email' => $email, 'aesKey' => $this->aesKey])->first();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)
  • ¥20 matlab yalmip kkt 双层优化问题
  • ¥15 如何在3D高斯飞溅的渲染的场景中获得一个可控的旋转物体
  • ¥88 实在没有想法,需要个思路
  • ¥15 MATLAB报错输入参数太多