Ormlite转义字符串方法?

发布于 2024-11-16 06:39:33 字数 391 浏览 3 评论 0原文

Android 版 Ormlite 是否有转义字符串的本机方法?

例如,如果我想提供一个字符串:ormlite's escape func,则需要将其作为 ormlite\'s escape func 提供。

TestDao.queryForFirst(TestDao.queryBuilder().where().like("stats", stats)
    .prepare())

我尝试使用 UpdateBuilder 的 escapeValue 方法,但它只进行以下更改: 'ormlite 的转义函数'。它在语句的开头和结尾添加单引号。是否有对转义字符串的本机支持以确保 SQL 注入安全?

如果不能的话,有哪些方法可以实现呢?

谢谢你!

Is there a native way of escaping strings for Ormlite for Android?

For example, if I want to supply a string: ormlite's escape func, it needs to be supplied as ormlite\'s escape func.

TestDao.queryForFirst(TestDao.queryBuilder().where().like("stats", stats)
    .prepare())

I tried using UpdateBuilder's escapeValue method, but it only makes the following change:
'ormlite's escape func'. It adds single quotes to beginning and end of the statement. Is there a native support for escaping strings to be sql injection safe?

If not, what are the ways to do it?

Thank you!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

撑一把青伞 2024-11-23 06:39:33

我尝试使用 UpdateBuilder 的 escapeValue 方法,但它只进行以下更改:“ormlite 的 escape func”。它在语句的开头和结尾添加单引号。是否有对转义字符串的本机支持以确保 SQL 注入安全?

这是常见问题解答。执行此操作的正确方法是使用 SelectArg 参数,以便 SQL 可以使用 ?构造类型。这是另一个讨论此问题的问题

SelectArg selectArg = new SelectArg(stats);
TestDao.queryForFirst(
    TestDao.queryBuilder().where().like("stats", selectArg).prepare());

以下是有关 select-arg 功能 的文档。

编辑:

正如@Moritz指出的,如果您实际上正在更新数据库,您还可以将SelectArgUpdateBuilder一起使用:

SelectArg arg = new SelectArg("Some value");
updateBuilder.updateColumnValue(MY_COLUMN, arg);

I tried using UpdateBuilder's escapeValue method, but it only makes the following change: 'ormlite's escape func'. It adds single quotes to beginning and end of the statement. Is there a native support for escaping strings to be sql injection safe?

This is a FAQ. The proper way to do this is to use a SelectArg argument so the SQL can use a ? type of construct. Here's another question talking about this.

SelectArg selectArg = new SelectArg(stats);
TestDao.queryForFirst(
    TestDao.queryBuilder().where().like("stats", selectArg).prepare());

Here's the documentation on the select-arg functionality.

Edit:

As @Moritz points out, if you are actually updating the database, you can also use the SelectArg with the UpdateBuilder:

SelectArg arg = new SelectArg("Some value");
updateBuilder.updateColumnValue(MY_COLUMN, arg);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文