getresource java_java – class.getResource(“.”)返回null
时间: 2024-04-07 09:27:46 浏览: 144
getResource() 方法会返回当前类所在的路径,而 "." 表示当前路径,所以在你的代码中,". "表示当前路径,而当前路径可能不是一个有效的资源路径,导致返回 null。你可以尝试使用 getClassLoader().getResource() 方法来获取资源,或者使用 getClass().getResource("/") 方法来获取当前类所在的根路径。如果还是无法获取资源,可以检查一下资源路径是否正确,并且资源是否已经被正确地打包到了 jar 包中。
相关问题
java.lang.Class.getResource用法?
java.lang.Class.getResource() 方法用于获取给定名称的资源,其默认行为是在调用此方法的类的classpath中查找资源。
该方法有两种形式:
1. public URL getResource(String name):返回具有给定名称的资源的URL,如果未找到该资源,则返回null。
2. public InputStream getResourceAsStream(String name):返回具有给定名称的资源的InputStream,如果未找到该资源,则返回null。
例如,假设我们有一个名为"sample.txt"的文本文件在类路径下的"resources"文件夹中。我们可以使用以下代码访问它:
```
InputStream inputStream = getClass().getResourceAsStream("/resources/sample.txt");
```
这将返回一个指向该文件的InputStream。注意,我们在资源名称前加上了"/",这是因为资源名称应该始终以"/"开头,以表示它是绝对路径。
@RestController public class LoginController { @Resource(name = "userServiceImpl") private IUserService userService; @RequestMapping(value = "/login/login", method = RequestMethod.POST, produces = {"application/json;charset=UTF-8"}) public Result<User> login(HttpRequest request, HttpServletResponse response) { return userService.login(request, response); } @RequestMapping(value = "/login/check", method = RequestMethod.POST, produces = {"application/json;charset=UTF-8"}) public Result<User> check(HttpServletRequest request, HttpServletResponse response) { Result<User> result = new Result<>(); String userId = SessionContext.get("user_id"); if (StringUtils.isEmpty(userId)) { Cookie loginTypeCookie = new Cookie("login_type", "0"); loginTypeCookie.setPath("/"); loginTypeCookie.setSecure(true); response.addCookie(loginTypeCookie); result.set("login_type", 0); } else { Cookie loginTypeCookie = new Cookie("login_type", "1"); loginTypeCookie.setPath("/"); loginTypeCookie.setSecure(true); response.addCookie(loginTypeCookie); result.set("login_type", 1); result.set("user_id", SessionContext.get("user_id")); result.set("user_name", SessionContext.get("user_name")); result.set("login_name", SessionContext.get("login_name")); result.set("user_image_id", SessionContext.get("user_image_id")); result.set("role_type", SessionContext.get("role_type")); // 检查token 是否需要更新 HttpSession session = request.getSession(false); if(session != null){ // 更新 session String issueAtStr = SessionContext.get("issueAt"); if(StringUtils.isNotEmpty(issueAtStr)){ Date issueAt = DateUtils.stringToDate(issueAtStr, DateConst.DATE_TIME_FORMAT_YYYY_MM_DD_HH_MI_SS_SSS); if(issueAt != null && TokenUtils.shouldTokenRefresh(issueAt)){ Map<String, Object> claims = new HashMap<>(10); claims.put("user_id", String.valueOf(SessionContext.getInt("user_id"))); claims.put("user_name", SessionContext.get("user_name")); claims.put("login_name", SessionContext.get("login_name")); claims.put("user_image_id", SessionContext.get("user_image_id")); claims.put("role_type", String.valueOf(SessionContext.getInt("role_type"))); String token = TokenUtils.createToken(claims); session.setAttribute("token", token); result.set("token", token); Cookie tokenCookie = new Cookie("token", token); tokenCookie.setPath("/"); response.addCookie(tokenCookie); } } } } return result; } @RequestMapping(value = "/login/exit", method = RequestMethod.POST, produces = {"application/json;charset=UTF-8"}) public Result<User> exit(HttpRequest request) { HttpSession session = request.getSession(false); if (session != null) { session.invalidate(); } return new Result<>(); } }
){ // 计算过期时间,过期时间不足半小时 更新 token long expireTime = issueAt.getTime() + (30 * 60 * 1000); // 过期时间为发放时间+30分钟 if(System.currentTimeMillis() >= expireTime){ // 需要更新 token String token = JWTUtils.createToken(SessionContext.get("user_id")); session.setAttribute("token", token); result.set("token", token); } } } } } return result; } }
请问这段代码实现了什么功能?
阅读全文