Asp.net core HTTP get请求是否可以不向URL传递很长的字符串?

Asp.net core HTTP get请求是否可以不向URL传递很长的字符串?,asp.net-core,model-binding,razor-pages,Asp.net Core,Model Binding,Razor Pages,传递很长的GET请求最有效的方法是什么?我在这里看到了一个类似的问题:哪个建议使用post请求而不是get?为什么会这样 例如,我有一个应用程序,其中包括4个多选列表和一个下拉列表。用户可以选择多个选项来筛选表格并显示结果。目前,这包括在我的onget方法中,方法是在URL中构建一个字符串,然后运行linq查询,根据用户的选择显示结果。这是可行的,但对我来说,传递这么长的URL似乎效率很低。有没有更好的方法来实现模型绑定 .cshtml文件: <select multiple class=

传递很长的GET请求最有效的方法是什么?我在这里看到了一个类似的问题:哪个建议使用post请求而不是get?为什么会这样

例如,我有一个应用程序,其中包括4个多选列表和一个下拉列表。用户可以选择多个选项来筛选表格并显示结果。目前,这包括在我的onget方法中,方法是在URL中构建一个字符串,然后运行linq查询,根据用户的选择显示结果。这是可行的,但对我来说,传递这么长的URL似乎效率很低。有没有更好的方法来实现模型绑定

.cshtml文件:

<select multiple class="form-control" name="CurSelDepts" asp-items="Model.DeptList" asp-for="SelDepts"></select>
<select multiple class="form-control" name="CurSelTechs" asp-items="Model.TechOneList" asp-for="SelTechs"></select>
<select multiple class="form-control" name="CurSelTech2s" asp-items="Model.TechTwoList" asp-for="SelTech2s"></select>
<select multiple class="form-control" name="CurSelRoles" asp-items="Model.RoleList" asp-for="SelRoles"></select>
<select class="form-control col-md-6" name="CurSelEmp" asp-items="Model.EmployeeList" asp-for="SelEmp">
    <option disabled selected style="display:none">--select--</option>
</select>
<input formmethod="get" type="submit" value="Search" class="btn btn-primary btn-sm" id="searchbtn" />
.cs文件:

public MultiSelectList DeptList { get; set; }
public MultiSelectList TechOneList { get; set; }
public MultiSelectList TechTwoList { get; set; }
public SelectList EmployeeList { get; set; }
public MultiSelectList RoleList { get; set; }
public int SelEmp { get; set; }
public int SelNewEmp { get; set; }
public int[] SelRoles { get; set; }
public int[] SelDepts { get; set; }
public int[] SelTechs { get; set; }
public int[] SelTech2s { get; set; }

public async Task OnGetAsync(int[] selRoles, int[] curSelRoles, int selEmp, int curSelEmp, int[] selDepts, int[] curSelDepts, int[] selTechs, int[] curSelTechs, int[] selTech2s, int[] curSelTech2s)
{
    DeptList = new MultiSelectList(_context.ppcc_deptCds, "Id", "dept_cd", SelDepts);
    TechOneList = new MultiSelectList(_context.ppcc_techCds, "Id", "tech_cd", SelTechs);
    TechTwoList = new MultiSelectList(_context.ppcc_techTwoCds, "Id", "tech_cd_two", SelTech2s);
    RoleList = new MultiSelectList(_context.ppcc_roles, "Id", "role_nm", SelRoles);
    EmployeeList = new SelectList(_context.employees, "Id", "employee_nm", SelEmp);

    SelEmp = curSelEmp;
    SelDepts = curSelDepts;
    SelTechs = curSelTechs;
    SelTech2s = curSelTech2s;
    SelRoles = curSelRoles;

    IQueryable<ppcc_matrix> ppcc_matrixIQ = from s in _context.ppcc_matrices select s;

    if (curSelDepts.Any())  {ppcc_matrixIQ = ppcc_matrixIQ.Where(s => curSelDepts.Contains(s.ppcc_deptCdId));}
    if (curSelTechs.Any())  {ppcc_matrixIQ = ppcc_matrixIQ.Where(s => curSelTechs.Contains(s.ppcc_techCdId));}
    if (curSelTech2s.Any()) {ppcc_matrixIQ = ppcc_matrixIQ.Where(s => curSelTech2s.Contains(s.ppcc_techTwoCdId));}
    if (curSelRoles.Any())  {ppcc_matrixIQ = ppcc_matrixIQ.Where(s => curSelRoles.Contains(s.ppcc_roleId));}
    if (curSelEmp != 0) { ppcc_matrixIQ = ppcc_matrixIQ.Where(s => s.employeeId.Equals(curSelEmp)); }
}

模型绑定可以处理GET请求和POST请求。您只需确保公共属性使用SupportsGet=true的BindProperty属性修饰:


对于很长的URL,有一个简单的例子。POST请求也有服务器施加的限制,但默认情况下会大得多。例如,它需要满足文件上传的需要。

是的,我忘了提到我已经尝试过这个,它对我不起作用。然而,我想知道这是否是因为在我的html文件中,我没有将这些选择列表包装在:。这可能是原因吗?或者这很重要?表单提交将只包括表单中控件的值,因此是的,如果您的select元素不在表单中,则在提交表单时,其所选值将不包括在有效负载中。
[BindProperty(SupportsGet=true)]
public Type MyProperty { get; set; }