java - erreur lors de l'ajout d'un cookie dans le servlet
滿天的星座
滿天的星座 2017-06-15 09:22:04
0
1
998

1. Erreur signalée lors de l'ajout de cookies :

An invalid character [13] was present in the Cookie value
  1. J'ai vérifié certains rapports d'erreurs sur Internet, la plupart d'entre eux sont [32], [44], qui seraient causés par l'ajout de "," ou d'espaces dans le cookie.

  2. Le code pour le traitement de la connexion est le suivant :

//登录处理
    @RequestMapping(value = "/login/validate", method = RequestMethod.POST)
    public void Validate(@RequestParam("username") String username, @RequestParam("password") String password,
                         HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) {
        String md5 = MD5Util.stringToMD5(password);
        if (userService.verification(username, md5)) {
            User user = userService.selectByUsername(username);
            Long id = user.getId();
            Long createDate = new Date().getTime();
            String str = id + "=" + createDate;
            //加密
            byte[] result = DESUtil.desCrypto(str, "12345678");

            //把加密的字节数组转换成16进制
//            String results = TypeUtil.bytesToHexString(result);
            String results = Base64.encodeBase64String(result);

            Cookie cookie = new Cookie("token", results);
            cookie.setMaxAge(60 * 60 * 24 * 7);//7天
            cookie.setPath("/");
            System.out.println("新生成cookie和其MaxAge:" + cookie.getName() + "-->" + cookie.getMaxAge());
            httpServletResponse.addCookie(cookie);
            HttpSession session = httpServletRequest.getSession();
            session.setAttribute("user", user);
            for (Cookie c : httpServletRequest.getCookies()) {
                System.out.println("cookes添加到response后重新获取cookies和其MaxAge:" + c.getName() + "-->" + c.getMaxAge());
            }
            try {
                httpServletResponse.sendRedirect("/index.html");
//                httpServletRequest.getRequestDispatcher("/index.html").forward(httpServletRequest, httpServletResponse);
            } catch (Exception e) {
                e.printStackTrace();
            }
        } else {
            try {
                httpServletResponse.sendRedirect("no.html");
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

L'erreur se produit ici dans addCookie.

滿天的星座
滿天的星座

répondre à tous(1)
代言

Après l'avoir essayé, il me suffit de commenter 2 et de publier 1 dans le code original. Quelqu'un peut-il l'expliquer ?

1. String results = TypeUtil.bytesToHexString(result);
2. //String results = Base64.encodeBase64String(result);
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!