-
Circular view path [login]: would dispatch back to the current handler URL [/login] again. Check your ViewResolver setup! (Hint: This may be the result of an unspecified view, due to default view name generation.)
将@Controller注解改为@RestController(@RestController是@Controller和@ResponseBody的结合体) -
使用mybatis plus自带的save方法报参数不匹配,但是我自己在mapper写save方法就会
java.lang.IllegalArgumentException: argument type mismatch
原因:
没有给自增长的id 加注解,在实体类的id上加@TableId(value = "id",type = IdType.AUTO)
-
net.bat100.crawlerDemo.common.exception.RedisConnectException: Could not get a resource from the pool
这个问题一般是redis配置错误,加上了这两个配置就好了
-
前后端分离时的跨域问题
前端:
新建一个axios.js,内容如下:
import axios from 'axios'
const request = axios.create({
baseURL: "http://127.0.0.1:9060",
responseType: 'json',
transformRequest: [(params) => {
let result = ''
Object.keys(params).forEach((key) => {
if (!Object.is(params[key], undefined) && !Object.is(params[key], null)) {
result += encodeURIComponent(key) + '=' + encodeURIComponent(params[key]) + '&'
}
})
return result
}],
headers: {
'Content-Type': 'application/x-www-form-urlencoded'
}
})
export default request
然后引入到main.js中
import request from './utils/axios'
Vue.prototype.$axios = request
向后端请求实例:
this.$axios.post("/login",{
userName: this.userName,
password: this.password
}).then((r) => {
console.log(r)
})
后端: 写一个过滤器,加请求头
@WebFilter(urlPatterns = "/*")
public class FilterConfig implements Filter {
@Override
public void init(javax.servlet.FilterConfig filterConfig) throws ServletException {
}
@Override
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain) throws IOException, ServletException {
System.out.println("过滤器");
HttpServletResponse response = (HttpServletResponse) servletResponse;
HttpServletRequest request = (HttpServletRequest)servletRequest;
response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));
response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
response.setHeader("Access-Control-Allow-Headers", request.getHeader("Access-Control-Request-Headers"));
// 跨域时会首先发送一个 option请求,这里我们给 option请求直接返回正常状态
if (request.getMethod().equals(RequestMethod.OPTIONS.name())) {
servletResponse.getOutputStream().write("Success".getBytes("utf-8"));
}else{
chain.doFilter(servletRequest,servletResponse);
}
}
@Override
public void destroy() {
}
}