我有一个非常奇怪的问题(使用 SL5,WCF DataServices 5.0.1):我有一个带有 2 个字符串参数(用户名、密码)的 ServiceOperation,它检查用户是否存在
public IQueryable<User> Login(string username, string password)
{...}
当我尝试调用它时,一切工作正常,除了密码哈希中包含“+”字符的情况。在这种情况下,它似乎被替换为空格字符:
var pwd = CRQWKrKzCcQVnlhk2zl0j5QM+c5ujQGMv0XXnh4genI=
this.Context.BeginExecute<User>(new Uri(string.Format("/Login?username='{0}'&password='{1}'", username, pwd), UriKind.Relative), (ar) => { .. }, null);
如果我用 Fiddler 抓住它,Request-Header 对我来说似乎没问题......
GET /Service.svc/Login?username='xyz'&password='CRQWKrKzCcQVnlhk2zl0j5QM+c5ujQGMv0XXnh4genI=' HTTP/1.1
但是在 WebForms-Tab 中,Password-QueryString 已经有一个空格而不是“+”。如果我在服务器上调试它,结果相同......
你们中有人知道为什么要替换“+”吗?是否还有其他无效字符?我怎样才能避免这种情况?
更新/编辑:
令人惊讶的是,以下查询按预期工作:
var query = (DataServiceQuery<User>) from c in this.Context.Users
where
c.Username.Equals(username.ToLower()) &&
c.Password.Equals(Cryptography.ComputeSha256Hash(password + username.ToLower()))
select c;
提前致谢!