在 ms sql server 上进行全文搜索时如何处理用户输入?
我在 ms sql server 上有一个简单的搜索机制,它使用全文“包含”。 我将搜索值作为参数传递给 contains 谓词 - 直接从用户的输入(通过 asp.net 网站)。 问题是我在各种情况下都会遇到 sql 异常: - 当用户输入两个单词时,例如“简单情况” - 当用户将 qoute 添加到搜索值时,例如“test”,
我使用如下查询进行了测试:
declare @val nvarchar(40)
set @val = N'test"' -- or 'simple case'
select x.* FROM xx as x
where CONTAINS(x.[name], @val)
通常我得到:“全文搜索条件‘xxx’中‘xxx’附近的语法错误。”问题是我想允许用户使用“*”、“or”和“and”条件进行高级查询,
您如何处理用户输入? 您引用名称值吗?
I have a simple search mechanism on ms sql server that uses full-text "contains".
I pass search value as a parameter to contains predicate - directly from user's input (via asp.net web site). The problem is that i get sql exception in variety of cases:
- when user inputs two words, like 'simple case'
- when user adds qoute to search value, like 'test"'
I have made test using query like below:
declare @val nvarchar(40)
set @val = N'test"' -- or 'simple case'
select x.* FROM xx as x
where CONTAINS(x.[name], @val)
Usually i get: "Syntax error near 'xxx' in the full-text search condition 'xxx'." The problem is that i would like to allow users to make advanced queries with '*', 'or' and 'and' conditions.
How do You handle user-input?
Do You qoutename value?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
在我们的应用程序中,我们使用自己的简单查询语言进行用户输入:仅操作数(带有可选通配符的单词或短语)、运算符(AND、OR、NOT)和括号。
我们解析用户输入,将其分解为各个组成部分并检查语法等。
如果我们认为输入有效,我们会将其重建为等效的
CONTAINS
条件并将其作为我们的搜索存储过程的参数。 因为我们自己创建条件,所以我们知道它在语法上是正确的。如果用户输入无效,那么我们可以向用户返回有意义的错误消息,而根本不需要连接到数据库。
In our app we use our own simple query language for the user input: just operands (words or phrases with optional wildcards), operators (AND, OR, NOT) and parentheses.
We parse the user input, break it down into it's constituent parts and check the syntax etc.
If we're happy that the input is valid, we rebuild it into the equivalent
CONTAINS
condition and send that as a parameter to our search sproc. Because we're creating the condition ourselves we know that it's syntactically correct.If the user input is invalid then we're able to return a meaningful error message to the user without needing to connect to the database at all.
几年前我用这个开发了一个应用程序; 我所做的是前端给你一个文本框来输入你的术语,它有一个下拉菜单可以在几个选项之间进行选择,如下所示:
所以我不希望他们输入 ands 或 ors - 我为他们这样做。 我确实让他们引用了一个子短语。
下面是一些完成此操作的代码。 结果短语作为参数发送给过程; 正如上面的评论者提到的,你确实必须这样做以防止 SQL 注入。 不幸的是,这段代码是遗留的 ASP VBScript,甚至没有按照该语言的标准编写得很好,但也许这会给您一个想法。
I built an app years ago using this; what I did is the front-end gives you a text box to type your terms and it has a drop-down to select between a few options like so:
So I don't want them typing ands or ors - I do that for them. I do let them quote a sub-phrase.
Below is some code that accomplishes this. The resulting phrase is sent as a parameter to a procedure; as the commenter above mentioned you really must do this to protect against SQL injection. Unfortunately this code is legacy ASP VBScript and isn't even well-written by that language's standards but maybe this gives you an idea.
根据您收到的错误,我想说您没有在查询中使用参数。 这是非常危险的,并且允许您的用户执行 sql 注入。
现在,对于您的问题,我认为最好的选择是您设置两种文本输入类型,一种用于普通用户,另一种用于高级用户,这样您就可以知道在哪里解析高级查询。
By the errors you are getting i would say you are not using parameters for your queries. This is very dangerous and allows your users to perform sql injections.
Now, as for your question, i think the best option would be for you to set 2 text entry types, one for regular users, another for advanced users so you can know where to parse for advanced queries.