Return 来自 select 的值,使用 FreeMarker

Return value from select using FreeMarker

我有一个表格:

     <form action="user-fonts" method="post" ">
        <select >
        <#list fonts as font>
        <option value=${font}>${font.nameFont?ifExists}</option>
        </#list>
        </select>
            <input type="hidden" name="_csrf" value="${_csrf.token}" />
            <div><input type="submit" value="Sign In"/></div>
        </form>

如何获取我在表单上选择的控制器中的值?

     @RequestMapping("/user-fonts")
public class MainController{
    @GetMapping
    public String main(@AuthenticationPrincipal User user, Model model)
    {
       Set<DBFont> fonts = user.getFont();
        model.addAttribute("fonts", fonts);
        return "Myfonts";
    }
    @PostMapping
    public String mainPost(@ModelAttribute DBFont DBfont)
    {

        System.out.println(DBfont.getNameFont());
         return "redirect:/user-fonts";
    }

数据库中有一个值,但是我得到null,如何return这个值?

您需要为 select 定义一个 name 属性,例如nameFont:

 <select name="nameFont">

这将发送字体 selected 值作为 POST 参数 nameFont