{"id":151407,"date":"2020-08-31T14:40:25","date_gmt":"2020-08-31T06:40:25","guid":{"rendered":"http:\/\/4563.org\/?p=151407"},"modified":"2020-08-31T14:40:25","modified_gmt":"2020-08-31T06:40:25","slug":"shiro-%e7%9a%84%e8%87%aa%e5%ae%9a%e4%b9%89-realm-%e4%b8%ad%e4%bd%bf%e7%94%a8-mapper-%e7%9a%84%e4%b8%80%e4%b8%aa%e5%be%88%e5%a5%87%e6%80%aa%e7%9a%84-bug","status":"publish","type":"post","link":"http:\/\/4563.org\/?p=151407","title":{"rendered":"shiro \u7684\u81ea\u5b9a\u4e49 realm \u4e2d\u4f7f\u7528 mapper \u7684\u4e00\u4e2a\u5f88\u5947\u602a\u7684 BUG"},"content":{"rendered":"<div>\n<div>\n<div>\n<h1>                  shiro \u7684\u81ea\u5b9a\u4e49 realm \u4e2d\u4f7f\u7528 mapper \u7684\u4e00\u4e2a\u5f88\u5947\u602a\u7684 BUG               <\/h1>\n<p> <\/p>\n<div>\n<div> <span>\u8cc7\u6df1\u5927\u4f6c : ShutTheFu2kUP <\/span>  <span><i><\/i> 20<\/span> <\/div>\n<div> <\/div>\n<\/p><\/div>\n<\/p><\/div>\n<\/p><\/div>\n<div isfirst=\"1\"> <\/p>\n<p>\u7b80\u5355\u63cf\u8ff0\u4e00\u4e0b\uff1a service \u4e2d\u5c06\u65b0\u7528\u6237\u7684\u6570\u636e\u63d2\u5165 user \u8868\uff0c\u7136\u540e\u628a userId \u4e22\u7ed9 shiro \u8fdb\u884c\u767b\u5f55\uff0c\u5927\u90e8\u5206\u7528\u6237\u90fd\u6ca1\u95ee\u9898\uff0c\u4f46\u662f\u5076\u5c14\u4f1a\u51fa\u73b0\u6709\u7684\u7528\u6237\u5728 realm \u4e2d\u901a\u8fc7 userId \u53bb\u6570\u636e\u5e93\u67e5\u8be2\u51fa\u7ed3\u679c\u4e3a null \u7684\u60c5\u51b5\uff0c\u5f71\u54cd\u4e86\u540e\u7eed\u903b\u8f91\u3002<\/p>\n<pre><code>\/\/ \u8fd9\u4e2a\u662f service \u4e2d\u767b\u5f55\u7684\u65b9\u6cd5 public void login(String userName, String password) {     \/\/ \u65b0\u589e\u7528\u6237     User user = new User();     user.setUserName(userName);     user.setPassword(password);          Integer userId = userMapper.insert(user);      \/\/ shiro \u767b\u5f55(\u4f7f\u7528\u81ea\u5b9a\u4e49 token)     UserToken userToken = userToken(userId);          SecurityUtil.getSubject.login(userToken);          \/\/ \u7ee7\u7eed\u4ee5\u4e0b\u903b\u8f91... } <\/code><\/pre>\n<pre><code>\/\/ \u8fd9\u4e2a\u662f\u81ea\u5b9a\u4e49 realm \u4e2d\u8fdb\u884c\u767b\u5f55\u7684\u65b9\u6cd5\uff0c\u4e0a\u9762 SecurityUtil.getSubject.login(userToken)\u4e4b\u540e\u5c31\u662f\u8dd1\u5230\u8fd9\u91cc\u9762\u6765 public class AuthRealm extends AuthorizingRealm {          private AuthenticationInfo getUserAuthInfo(UserToken token) throws AuthenticationException{         Integer userId = token.getUserId();         User user = userMapper.selectById(userId);                  if(user == null) {             \/\/ \u6b64\u5904\u5c31\u662f BUG \u70b9\uff0c\u5927\u90e8\u5206\u7528\u6237\u6b63\u5e38\uff0c\u5076\u5c14\u51fa\u73b0\u4e00\u4e2a\u7528\u6237\u67e5\u8be2\u51fa\u6765\u7684 user \u4e3a null\uff0c\u4e14\u6253\u5370\u65e5\u5fd7\u4f20\u8fdb\u6765 token \u4e2d\u7684 userId \u6709\u503c\uff0c\u67e5\u6570\u636e\u5e93\u4e5f\u6709\u5bf9\u5e94\u6570\u636e             LOGGER.error(\"\u627e\u4e0d\u5230\u7528\u6237\u8d26\u53f7:{}\", token.getUserId());             throw new UnknownAccountException();\/\/\u6ca1\u627e\u5230\u5e10\u53f7         } else {             AuthenticationInfo authcInfo = new SimpleAuthenticationInfo(userId.toString(), userId.toString(), this.getName());             return authcInfo;         }     }      } <\/code><\/pre>\n<p>\u4e0d\u8981\u95ee\u6211\u4e3a\u4ec0\u4e48\u8fd8\u8981\u5728 realm \u91cc\u9762\u67e5\u4e00\u904d\uff0c\u8fd9\u6bb5\u4ee3\u7801\u4e0d\u662f\u6211\u5199\u7684\uff0c\u4f46\u662f\u5c31\u662f\u5bf9\u8fd9\u4e2a BUG \u611f\u5230\u5f88\u7591\u60d1\uff0c\u5e0c\u671b\u6709\u5927\u4f6c\u80fd\u591f\u89e3\u7b54\u3002<\/p>\n<\/p><\/div>\n<div> <b>\u5927\u4f6c\u6709\u8a71\u8aaa<\/b> (<span>1<\/span>)        <\/div>\n<div> <\/div>\n<\/p><\/div>\n<\/p><\/div>\n<ul>\n<li data-pid=\"2980224\" data-uid=\"2\">\n<div>\n<div>\n<div> <span>\u4e3b<\/span> <span>\u8cc7\u6df1\u5927\u4f6c : ShutTheFu2kUP <\/span>  <\/div>\n<div> <i title=\"\u5f15\u7528\"><\/i>  <span>          <\/span> <\/div>\n<\/p><\/div>\n<div>                                                             \u597d\u5427\uff0c\u6ca1\u95ee\u9898\u4e86\uff0c\u53ea\u662f\u4e3b\u4ece\u5e93\u5bfc\u81f4\u7684\u3002                                                            <\/div>\n<\/p><\/div>\n<\/li>\n<li>\n","protected":false},"excerpt":{"rendered":"<p>shiro \u7684\u81ea\u5b9a\u4e49 realm &hellip;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[],"tags":[],"_links":{"self":[{"href":"http:\/\/4563.org\/index.php?rest_route=\/wp\/v2\/posts\/151407"}],"collection":[{"href":"http:\/\/4563.org\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/4563.org\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/4563.org\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/4563.org\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=151407"}],"version-history":[{"count":0,"href":"http:\/\/4563.org\/index.php?rest_route=\/wp\/v2\/posts\/151407\/revisions"}],"wp:attachment":[{"href":"http:\/\/4563.org\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=151407"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/4563.org\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=151407"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/4563.org\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=151407"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}