【发布时间】:2017-03-07 05:52:17
【问题描述】:
我修改了 ASP.NET Identity 2.0 Extending Identity Models 以便使用 int 键而不是字符串 (GUID),如 ASP.NET Identity 2.0 Extending Identity Models and Using Integer Keys Instead of Strings 所示,并修改了一些方法的逻辑,如下所示:
public async Task<ActionResult> Details(string id)
{
if (id == null)
{
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
var user = await UserManager.FindByIdAsync(id);
ViewBag.RoleNames = await UserManager.GetRolesAsync(user.Id);
return View(user);
}
到这里:
public async Task<ActionResult> Details(int id)
{
if (id > 0)
{
// Process normally:
var user = await UserManager.FindByIdAsync(id);
ViewBag.RoleNames = await UserManager.GetRolesAsync(user.Id);
return View(user);
}
// Return Error:
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
另一方面,我不想改变逻辑,只想改变 if 块中的条件,但我不确定检查 int 的空值的最佳方法是什么?
原来的方法是这样的:
if (id == null) //id is string
由于我必须将字符串更改为 int 类型,因此我需要检查 null 类似的内容:
if (id !> 0) //id is int
有什么想法吗?
【问题讨论】:
-
Int 不能为空,最好的办法是使用 -1 作为空值(假设永远不会正常使用)
-
If (id == 0)。但最好将其设为int?(可为空),以便您可以使用if (!id.HasValue) -
这个问题不清楚。你展示的方法是一个action方法,所以是通过MVC调用的。您有哪些预期的用例?你有什么错误处理?如果用户在调用此操作方法时省略了
id参数会发生什么?当他们请求将id设置为0的页面时,您希望发生什么?你真正想做什么? -
@StephenMuecke 我不应该使用可为空的 int 作为 id 参数也依赖。那么,使用 if (id == 0) 而不是 if (id == null) 可以吗?谢谢...
-
为什么不让它可以为空呢?但我假设你的数据库中不会有
id = 0的记录,所以应该没问题。
标签: c# asp.net asp.net-mvc if-statement null