如何配置filter过滤器,如何放行而不是全部拦截

配置过滤器次次失败,比如我通过servlet验证登录,然后我允许验证登录的servlet请求通过以及注册页面,我该如何配置

web.xml

 <filter>
    <filter-name>loginFilter</filter-name>
    <filter-class>com.lero.filter.LoginFilter</filter-class>
  </filter>

  <filter-mapping>
    <filter-name>loginFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

为什么我写的拦截器跳不到login.jsp同事resister.jsp也通过不了

    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
            throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        HttpSession session = request.getSession();
        Object object = session.getAttribute("name");
        String path = request.getServletPath();
        if ( path.indexOf("register") >-1) {

            filterChain.doFilter(servletRequest, servletResponse);
            return;
        } else {
            response.sendRedirect("login.jsp");
        }
    }

然后我这样写虽然都通过了,但页面确实空白

    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain)
            throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest) servletRequest;
        HttpServletResponse response = (HttpServletResponse) servletResponse;
        HttpSession session = request.getSession();
        Object object = session.getAttribute("name");
        String path = request.getServletPath();
        if ( path.indexOf("login") >=0) {

            filterChain.doFilter(request, response);
            return;
        } else if(path.indexOf("redister.jsp")>-1){
            filterChain.doFilter(request, response);
        }
    }

5个回答

<welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
这里的都不会被拦截
weixin_36876700
混沌太初 回复睡不着就洗洗起吧: 你有做测试么?你把拿到的String path = request.getServletPath();把path打印出来,看是不是你想要的结果,getServletPath():获取能够与“url-pattern”中匹配的路径,注意是完全匹配的部分,*的部分不包括
12 个月之前 回复
qq_36750352
喜只狼果冻 看问题里新的代码
12 个月之前 回复

正常的系统,肯定需要都拦截吧 不然要拦截器干嘛,如果想放行一些不想拦截的 看看这个例子吧,
https://www.cnblogs.com/liyangxj/p/4506148.html

qq_36750352
喜只狼果冻 我重新上传一个图,你看我写的有什么问题
12 个月之前 回复

在web中添加个filter拦截就可以了

qq_36750352
喜只狼果冻 我重新上传一个图,你看我写的有什么问题
12 个月之前 回复

/*
改成

<url-pattern>/</url-pattern>

过滤器的过程就是先从jsp页面获取数据,传到selevt里面进行对比,正确就返回,不正确就再跳转到另外一个报错jsp页面

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
filter 器问题 配置一个简单的过滤器 可是无法拦截到请求
<filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> http://localhost:8080/board/control/employee/list.action 可以拦截到http://localhost:8080/board/control/employee/manage.action 无法拦截到这是为什么? Action 我用的是 struts2 这是我的 struts.xml 文件的配置 <package name="employee" extends="struts-default" namespace="/control/employee"> <action name="list" class="/control/employee/list"> <result name="list">/WEB-INF/page/department/employeelist.jsp</result> </action> <action name="manage" class="/control/employee/manage"> <result name="addEmployee"> /WEB-INF/page/department/addemployee.jsp </result> <result name="employeeNameIsExsit"> /WEB-INF/page/department/addemployee.jsp </result> <result name="list" type="redirectAction"> <param name="actionName">list</param> </result> <result name="editEmployee"> /WEB-INF/page/department/editemployee.jsp </result> <result name="input"> /WEB-INF/page/department/addemployee.jsp </result> </action> </package>
Struts2项目中配置的自定义过滤器无效
Struts2的核心过滤器不用多说,配置如下 [code="java"] <filter> <filter-name>Struts2</filter-name> <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class> </filter> <filter-mapping> <filter-name>Struts2</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> [/code] 此外,还配置了一个自定义的过滤器,<url-pattern>*.html</url-pattern> (我的Struts2请求后缀是html) 结果没有进入这个过滤器,把*.html改成/*就行了,但是这个过滤器只负责拦截html,如果写/*的话所有都会拦截,比如js, css等,这样就不符合本意了,请指点。 拦截器就不用说了,我暂时不考虑用拦截器,不想因为是Struts2就放弃了原先的过滤器。 请都先看清楚了再回答,没素质的疯子远离,谢谢
新手求助:filter过滤器的问题
web.xml配置 ``` <filter> <filter-name>loginInterceptor</filter-name> <filter-class>com.cbt.Interceptor.LoginInterceptor</filter-class> <init-param> <param-name>loginPage</param-name> <param-value>main_login</param-value> </init-param> </filter> <filter-mapping> <filter-name>loginInterceptor</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <filter-mapping> <filter-name>loginInterceptor</filter-name> <url-pattern>*.jsp</url-pattern> </filter-mapping> <filter-mapping> <filter-name>loginInterceptor</filter-name> <url-pattern>*.html</url-pattern> </filter-mapping> <servlet> <servlet-name>cbtconsole</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring/springmvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>cbtconsole</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> ``` springmvc配置 ``` <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/jsp/" /> <property name="suffix" value=".jsp" /> </bean> <!-- 资源映射:因为servlet-mapping会拦截所有请求.需要过滤掉静态资源请求 --> <mvc:resources location="/WEB-INF/css/" mapping="/css/**" /> <mvc:resources location="/WEB-INF/js/" mapping="/js/**" /> ``` 过滤器代码 ``` @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest httpServletRequest = (HttpServletRequest) request; HttpServletResponse httpServletResponse = (HttpServletResponse) response; String urlPath = httpServletRequest.getRequestURL().toString(); String value = jedisClient.get("key1"); System.out.println(urlPath+"---"+value); if (value !=null) { chain.doFilter(request, response); }else{ httpServletResponse.sendRedirect(urlPath + loginPage); } } @Override public void init(FilterConfig config) throws ServletException { //context-param –> listener –> filter –> servlet loginPage = config.getInitParameter("loginPage"); ServletContext context = config.getServletContext(); ApplicationContext ctx = WebApplicationContextUtils.getWebApplicationContext(context); jedisClient = (JedisClient) ctx.getBean("jedisClient"); } ``` 输入localhost:8080进入过滤器后直接死循环了. 求大神指点
filter过滤器的奇怪问题
配置了一个filter,代码: public class ThreadFilter implements Filter{ public void init(FilterConfig filterConfig) throws ServletException { } public void destroy() { } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException { HttpServletRequest req=(HttpServletRequest)request; System.out.println(req.getSession().getId()); Threadbean.getInstance().setContext(req.getSession().getId()); System.out.println("开始了..."); chain.doFilter(request, response); } } 一开始启动tomcat到主页的时候filter会拦截两次,输出了两次信息,我的主页并没有使用action转发,后面就碰到有时候拦截不到的问题,信息没有输出,配置如下: <filter> <filter-name>threadfilter </filter-name> <filter-class>com.shop.util.ThreadFilter </filter-class> </filter> <filter-mapping> <filter-name>threadfilter </filter-name> <url-pattern>/* </url-pattern> </filter-mapping> 是代码出错了还是配置出错了,filter要注意哪些细节上的问题?
Struts2 过滤器和拦截器执行的顺序
在web.xml ,定义首页位置: [code="xml"] <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> [/code] 并配置了一个filter,用于过滤对jsp的直接访问. [code="xml"] <filter> <filter-name>indexfilter</filter-name> <filter-class>com.prodinfo.filter.IndexFilter</filter-class> </filter> <filter-mapping> <filter-name>indexfilter</filter-name> <url-pattern>/index.jsp</url-pattern> </filter-mapping> [/code] [code="java"] ...... public class IndexFilter implements Filter { ...... public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest re = (HttpServletRequest) request; HttpSession session = re.getSession(); //redirect to action request.getRequestDispatcher("loadindex.action?id=xxx").forward( request, response); System.out.println("i am filter"); } ...... } [/code] struts.xml中配置了interceptor,拦截用户的请求,在action执行之前,load页面信息,然后继续. [code="xml"] <interceptors> <interceptor name="LoadHeaderFooter" class="loadHeaderFooter"> </interceptor> <interceptor-stack name="InterceptorStack"> <interceptor-ref name="defaultStack" /> <interceptor-ref name="LoadHeaderFooter" /> </interceptor-stack> </interceptors> <action name="loadindex" class="companyInfoAction" method="loadCompanyInfo"> <result name="success">/index.jsp</result> <interceptor-ref name="LoadHeaderFooter"></interceptor-ref> </action> [/code] [code="java"] ...... public String intercept(ActionInvocation invocation) throws Exception { //System.out.println("Before Action"); //get header & footer infomation List result = ci.getHeaderFooter("xxx"); ...... System.out.println("i am interceptor"); final String res = invocation.invoke(); //System.out.println("After Action"); return res; } ...... [/code] 我理解的执行顺序是(<welcome-file-list>)index.jsp->(filter)"loadindex.action?id=xxx"->(interceptor)"loadHeaderFooter"->(Action)"loadindex"->(jsp)index.jsp 可是现在执行的顺序是先interceptor再filter,程序运行打印结果是: i am interceptor loading company info of null i am filter 请问我该在哪里配置filter 和 interceptor的顺序呢? 谢谢! [b]问题补充:[/b] 谢谢 蔡华江 的回复. 即是说我应该从web.xml里filter的位置来下手找我的问题的原因? [b]问题补充:[/b] 去掉了interceptor,发现还是先执行的action再进的filter. Struts2的执行顺序一定是先action再filter? 已经把FilterDispatcher放到web.xml最上面了.
Filter过滤器,过滤后登陆界面无法正常跳转,好像一直重定向到登陆界面,就大神看看
这是我Filter的代码 public class FilterServlet extends HttpServlet implements Filter { private FilterConfig config; public void init(FilterConfig config) throws ServletException { // TODO Auto-generated method stub this.config=config; System.out.print("过滤器已执行"); } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // TODO Auto-generated method stub //获取Filter的配置参数 String loginpage= config.getInitParameter("loginpage"); HttpServletRequest req = (HttpServletRequest) request; String requestPath = req.getServletPath(); //StringBuffer fileURL = req.getRequestURL(); // 存储上下文路径 request.setAttribute("path", req.getContextPath()); if(!requestPath.endsWith(loginpage)){ // 跳转到登录页面 request.getRequestDispatcher(loginpage) .forward(request, response); }else{ chain.doFilter(request, response); } } /** * Constructor of the object. */ public FilterServlet() { super(); } /** * Destruction of the servlet. <br> */ public void destroy() { super.destroy(); // Just puts "destroy" string in log // Put your code here this.config = null; } public void init() throws ServletException { // TODO Auto-generated method stub } } 下面是我再web.xml文件中配置的Filter <filter-name>pathfilter</filter-name> <filter-class>com.personnel.filter.FilterServlet</filter-class> <init-param> <param-name>loginpage</param-name> <param-value>/login.jsp</param-value> </init-param> </filter> <filter-mapping> <filter-name>pathfilter</filter-name> <!-- struts2匹配根路径下的全部请求,拦截所以用户请求 ,在日志中简要记录请求的信息--> <url-pattern>/*</url-pattern> </filter-mapping> 我只要把if的内容注释掉就能正常跳转,但是过滤功能无法实现,如上代码的过滤功能能够实现,无法点开除login.jsp以外的界面 ,但是按登录按钮无法进行正常的跳转,一直重定向为登录界面,求大神解答
struts2 拦截器和filter过滤器哪个性能更好些?
如题 :evil:
配置拦截器后JSP页面找不到引用的javascript
拦截器配置成功后原jsp页面引用的js404了 js引用如下 ``` <script type='text/javascript' src='<%=basePath%>admin/js/aclock.js'></script> <script type="text/javascript" src="<%=basePath%>admin/eventJS/sharingJS.js"></script> ``` web.xml如下: ``` <filter> <filter-name>Login</filter-name> <filter-class>com.xxxx.Util.LoginFilter</filter-class> </filter> <filter-mapping> <filter-name>Login</filter-name> <url-pattern>/admin/*</url-pattern> <url-pattern>/views/*</url-pattern> </filter-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>/js/*</url-pattern> <url-pattern>/css/*</url-pattern> <url-pattern>/images/*</url-pattern> </servlet-mapping> ``` 拦截器如下: ``` public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2) throws IOException, ServletException { HttpServletRequest req = (HttpServletRequest) arg0; HttpServletResponse resp = (HttpServletResponse) arg1; HttpSession session = req.getSession(); String path = req.getRequestURI(); System.out.println(path); String admin_account = (String) session.getAttribute("admin_account"); if(path.indexOf("image.jsp") > -1){ arg2.doFilter(req, resp); return; }else {// 如果不是login.jsp进行过滤 if (admin_account == null || "".equals(admin_account)) { resp.sendRedirect("/stone-bi/index.jsp"); } else { // 已经登陆,继续此次请求 arg2.doFilter(req, resp); } } } ```
shiro提取filter拦截器中的map数据存放到yml配置文件中的问题
最近在整合shiro,想把URL和权限什么的提取出来放在yml里,但是yml中的map数据却读取不到。。。 ``` @Configuration @Component @ConfigurationProperties(prefix="shiroConfig") public class ShiroConfig { @Value("shiroConfig.filterChainDefinitionMap") private Map filterChainDefinitionMap = new LinkedHashMap(); public Map getFilterChainDefinitionMap() { return filterChainDefinitionMap; } public void setFilterChainDefinitionMap(Map filterChainDefinitionMap) { this.filterChainDefinitionMap = filterChainDefinitionMap; } ``` @Bean @Autowired public ShiroFilterFactoryBean getShiroFilterFactoryBean(@Qualifier("securityManager") DefaultWebSecurityManager securityManager, View view,ShiroConfig shiroConfig){ ShiroFilterFactoryBean shiroFilterFactoryBean = new ShiroFilterFactoryBean(); // 设置安全管理器 shiroFilterFactoryBean.setSecurityManager(securityManager); //设置登录的页面,发送toLogin请求 shiroFilterFactoryBean.setLoginUrl(view.getLogin()); //设置未授权的页面 shiroFilterFactoryBean.setUnauthorizedUrl(view.getUnauthorized()); //设置过滤器 shiroFilterFactoryBean.setFilterChainDefinitionMap(shiroConfig.getFilterChainDefinitionMap()); return shiroFilterFactoryBean; } ``` yml文件 shiroConfig: filterChainDefinitionMap: /testThymeleaf: anon /login: anon /add: perms[user:add] /update: perms[user:update] /*: authc ```
Filter改用struts2 interceptor实现
之前公司使用Filter做页面级缓存,实现代码大致如下 CacheHettpServletResponseWrapper wrapper = new CacheHettpServletResponseWrapper (respone); String result = cache.get(key); if(result==null || "".equals(result)){ chain.doFilter(reques, wrapper); result = wrapper.getContent(); cache.put(key,result); return; } response.write(result); 之前这段逻辑是写在了过滤器里,前面也有判断,把url配置在过滤器中。 但是本人想把他写在拦截器里,请问有方法实现吗?请高人指教!
关于tomcat拦截器的问题,
<p><span style="font-size: medium;">我想做一个全局的tomcat拦截器,既能拦截用户的请求(请求信息,参数等),也要拦截web服务器返回的response。</span></p> <p> </p> <p><span style="font-size: medium;">拦截用户请求已经搞定了</span></p> <p><span style="font-size: medium;">但是怎么拦截web服务返回的结果response呢,我要处理返回的response页面,对返回的页面进行相应的处理,即要解析这个返回的response页面,大家有啥建议否?或者更好的方法?<img src="/images/smiles/icon_biggrin.gif" alt=""></span></p>
Java中加入登陆拦截器后,post put delete请求全部405,只有get请求可以访问。请问应该怎么解决?
下面是我拦截器的代码。 ``` public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { // 获得在下面代码中要用的request,response,session对象 HttpServletRequest httpRequest = (HttpServletRequest) servletRequest; HttpServletResponse httpResponse = (HttpServletResponse) servletResponse; HttpSession session = httpRequest.getSession(true); String[] str = {"login","docs"}; // 路径中包含这些字符串的,可以不用登录直接访问 StringBuffer url = httpRequest.getRequestURL(); // 特殊用途的路径可以直接访问 if (str != null && str.length > 0) { for (String s : str) { if (url.indexOf(s) >= 0) { filterChain.doFilter(servletRequest, servletResponse); return; } } } // 从session中获取用户信息 String loginInfo = (String) session.getAttribute("username"); if (null != loginInfo && !"".equals(loginInfo)) { // 用户存在,可以访问此地址 filterChain.doFilter(servletRequest, servletResponse); } else { // 用户不存在,踢回登录页面 // String a = httpRequest.getContextPath()+"/login/notLogin"; servletRequest.getRequestDispatcher("/login/notLogin").forward(servletRequest, httpResponse); return; } } ``` 这里是我web.xml的配置 ``` <!-- 登录过滤器 --> <filter> <filter-name>LoginFilter</filter-name> <filter-class>aa.filter.LoginFilter</filter-class> </filter> <filter-mapping> <filter-name>LoginFilter</filter-name> <url-pattern>/aa/*</url-pattern> <url-pattern>/bb/*</url-pattern> <url-pattern>/cc/*</url-pattern> <url-pattern>/dd/*</url-pattern> <url-pattern>/ee/*</url-pattern> </filter-mapping> ``` 接口是restful接口。 有大神知道原因吗?
过滤器问题tomact已启动就报错
严重: Exception starting filter Filter java.lang.ClassNotFoundException: com.hp.filter.Filter at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1358) at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1204) at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:249) at org.apache.catalina.core.ApplicationFilterConfig.setFilterDef(ApplicationFilterConfig.java:397) at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:108) at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:3693) at org.apache.catalina.core.StandardContext.start(StandardContext.java:4340) at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791) at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771) at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525) at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:920) at org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:883) at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492) at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1138) at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311) at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117) at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053) at org.apache.catalina.core.StandardHost.start(StandardHost.java:719) at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045) at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443) at org.apache.catalina.core.StandardService.start(StandardService.java:516) at org.apache.catalina.core.StandardServer.start(StandardServer.java:710) at org.apache.catalina.startup.Catalina.start(Catalina.java:566) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) at java.lang.reflect.Method.invoke(Method.java:597) at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288) at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413) 2016-6-14 22:15:55 org.apache.catalina.core.StandardContext start 严重: Error filterStart 2016-6-14 22:15:55 org.apache.catalina.core.StandardContext start 严重: Context [/web10] startup failed due to previous errors 1我的过滤器代码是: package com.web.filter; import java.io.IOException; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * 实现过滤器功能 * @author Administrator * */ public class Filter implements javax.servlet.Filter { private FilterConfig config; @Override public void destroy() { // TODO Auto-generated method stub } @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { System.out.println("doFilter"); // TODO Auto-generated method stub /** * 获取httprequest对象 */ HttpServletRequest httprequest = (HttpServletRequest) request; /** * 获取httpresponse对象 */ HttpServletResponse httpresponse = (HttpServletResponse) response; /** * 获取上下文参数 */ String noPat = config.getInitParameter("noPaths"); /** * 分割字符 */ String[] str = noPat.split(";"); /** * 循环遍历 分割的字符串 */ for (int i = 0; i < str.length; i++) { /** * 为空结束本次循环 */ if (str[i] != null && "".equals(str[i])) continue; /** * indexOf返回不为-1 放行 */ if (httprequest.getRequestURI().indexOf(str[i]) != -1) { chain.doFilter(request, response); return; } } /** * 获取session中的username(用户名) */ String username = (String) httprequest.getSession().getAttribute( "username"); /** * 用户名不为空 放行 */ if (username != null) { chain.doFilter(request, response); } /** * 用户名为空 拦截并返回登录页面 */ else { httpresponse.sendRedirect("login.jsp"); } } @Override public void init(FilterConfig filterConfig) throws ServletException { // TODO Auto-generated method stub config = filterConfig; System.out.println("init******************"); } } 配置文件是: <?xml version="1.0" encoding="UTF-8"?> <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <!-- Filter --> <filter> <filter-name>Filter</filter-name> <filter-class>com.hp.filter.Filter</filter-class> <init-param> <param-name>noPaths</param-name> <param-value>index.jsp;</param-value> </init-param> </filter> <filter-mapping> <filter-name>Filter</filter-name> <url-pattern>*.jsp;*.html</url-pattern> </filter-mapping> <!-- IndexLoginServlet 登陆配置--> <servlet> <servlet-name>IndexLoginServlet</servlet-name> <servlet-class>com.web.servlet.IndexLoginServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>IndexLoginServlet</servlet-name> <url-pattern>/IndexLoginServlet</url-pattern> </servlet-mapping> <!-- Indext2RegisterServlet注册配置 --> <servlet> <servlet-name>Indext2RegisterServlet</servlet-name> <servlet-class>com.web.servlet.Indext2RegisterServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>Indext2RegisterServlet</servlet-name> <url-pattern>/Indext2RegisterServlet</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app>
c++使用api开发防火墙软件如何在界面显示拦截记录
原理是利用windows自带的api函数,将过滤条件绑定到接口,再把接口绑定到本地ip地址,实现过滤。但是这种办法不知道如何显示每次的拦截记录,有什么思路可以实现界面显示拦截记录吗? 希望**做过这个的**大大提点自己的意见 ``` CIpFilter::CIpFilter() { bCreateInterfaceSuccess = false; ruleCount = 0; /* 创建一个根据过滤规则丢弃数据包的过滤接口 */ DWORD retD = PfCreateInterface( 0, PF_ACTION_FORWARD, PF_ACTION_FORWARD,FALSE, TRUE, &drop ); ///* 创建一个根据过滤规则放行数据包的过滤接口 */ //DWORD retD = PfCreateInterface( 0, PF_ACTION_DROP, PF_ACTION_DROP,FALSE, FALSE, &drop ); if(retD == NO_ERROR){ bCreateInterfaceSuccess = true; } in_addr ip = GetLocalIP(); localInAddr = ip.S_un.S_addr; } CIpFilter::~CIpFilter() { if(bCreateInterfaceSuccess){ PfDeleteInterface(drop); } } /** * 通过将过滤接口绑定到本地IP的方法使得过滤器发生作用 * **/ bool CIpFilter::Filtering() { DWORD retD = PfBindInterfaceToIPAddress(drop,PF_IPV4,(PBYTE) & localInAddr); return (retD == NO_ERROR); } /** * 通过将过滤接口取消与本地IP的绑定的方法使得过滤器不再发生作用 * **/ bool CIpFilter::UnFiltering() { DWORD retD = PfUnBindInterface(drop); return (retD == NO_ERROR ); } /** * 向IP过滤器增加一条规则,先根据规则创建一个Filter描述子, * 然后把Filter描述子加入到与IP过滤器相关的Interface即可 * **/ bool CIpFilter::AddRule(RuleInfo rule) { PF_FILTER_DESCRIPTOR pf ; /* 创建Filter描述子 */ pf.dwFilterFlags = FD_FLAGS_NOSYN; int a = FD_FLAGS_NOSYN; pf.dwRule = 0; pf.pfatType = PF_IPV4; pf.fLateBound = 0; pf.dwProtocol = rule.protocol; pf.wSrcPort = rule.sourcePort; pf.wDstPort = rule.destinationPort; pf.SrcAddr = (PBYTE) & rule.sourceIp; pf.SrcMask = (PBYTE) & rule.sourceMask; pf.DstAddr = (PBYTE) & rule.destinationIp; pf.DstMask = (PBYTE) & rule.destinationMask; pf.wSrcPortHighRange = pf.wSrcPort; pf.wDstPortHighRange = pf.wDstPort; DWORD ret; /* 根据规则过滤数据包的方向来把Filter描述子加入到Inteface中 */ if(rule.bOut) ret = PfAddFiltersToInterface(drop,0,NULL,1,&pf,NULL); else ret = PfAddFiltersToInterface(drop,1,&pf,0,NULL,NULL); if(ret == NO_ERROR) ruleCount ++; return ret == NO_ERROR; } /** * 删除与指定规则相关的Interface 中的Filter描述子 * **/ bool CIpFilter::DeleteRule(RuleInfo rule) { PF_FILTER_DESCRIPTOR pf ; /* 根据规则生成与该规则相应的Filter描述子*/ pf.dwFilterFlags = FD_FLAGS_NOSYN; int a = FD_FLAGS_NOSYN; pf.dwRule = 0; pf.pfatType = PF_IPV4; pf.fLateBound = 0; pf.dwProtocol = rule.protocol; pf.wSrcPort = rule.sourcePort; pf.wDstPort = rule.destinationPort; pf.SrcAddr = (PBYTE) & rule.sourceIp; pf.SrcMask = (PBYTE) & rule.sourceMask; pf.DstAddr = (PBYTE) & rule.destinationIp; pf.DstMask = (PBYTE) & rule.destinationMask; pf.wSrcPortHighRange = pf.wSrcPort; pf.wDstPortHighRange = pf.wDstPort; DWORD ret; /* 根据规则过滤数据包的方向来删除Interface中与它相关的Filter描述子 */ if(rule.bOut) ret = PfRemoveFiltersFromInterface(drop,0,NULL,1,&pf); else ret = PfRemoveFiltersFromInterface(drop,1,&pf,0,NULL); if(ret == NO_ERROR) ruleCount --; return ret == NO_ERROR; } /** * 通过释放与过滤器相关的Interface, * 再重新生成一个新的Interface, * 最后把新Interface过滤器关联起来, * 从而实现了清除所有过滤规则的功能 * **/ bool CIpFilter::ClearAllRules() { bool result = false; DWORD retDD = PfDeleteInterface(drop); DWORD retDC = PfCreateInterface( 0, PF_ACTION_DROP, PF_ACTION_DROP,FALSE, TRUE, &drop ); if(UnFiltering() && retDD == NO_ERROR && retDC == NO_ERROR){ result = true; } return result; } /** * 通过Windows Socket来取得本地IP * **/ in_addr CIpFilter::GetLocalIP() { WORD wVersionRequested; WSADATA wsaData; hostent* localHost; wVersionRequested = MAKEWORD( 2, 2 ); WSAStartup( wVersionRequested, &wsaData ); localHost = gethostbyname(""); WSACleanup(); in_addr* localIP = (struct in_addr *)localHost->h_addr_list[0]; return *localIP; } /** * 调用API 取得与过滤器相关的Interface相关的状态数据 * **/ PF_INTERFACE_STATS * CIpFilter::GetState() { PF_INTERFACE_STATS * ret; DWORD size = 0, retFlag = 0; int x = sizeof(PF_INTERFACE_STATS); ret = (PF_INTERFACE_STATS *)new char[sizeof(PF_INTERFACE_STATS)]; retFlag = PfGetInterfaceStatistics(drop,ret,&size,FALSE); if(retFlag != NO_ERROR) { /*重复一定的调用次数,以提供成功调用的概率*/ for(int i = 0; i < 10; i ++){ delete ret; ret = (PF_INTERFACE_STATS *)new char[size]; retFlag = PfGetInterfaceStatistics(drop,ret,&size,FALSE); if(retFlag == NO_ERROR) break; } if(retFlag != NO_ERROR) return NULL; } return ret; } ```
过滤器过滤特殊字符无法获取到参数
代码如下: ``` $.ajax({ url: url, type: 'post', data: o, cache: false, success: function (text) { console.dir(text); CloseWindow("save"); }, error: function (jqXHR, textStatus, errorThrown) { alert(jqXHR.responseText); CloseWindow(); } }); ``` 我使用ajax方式提交,post提交方式,手动封装data。 后端接收如下: ``` @At("/updateProductCfg") public ExecuteState updateProductCfg(@Param("..") CmsLoanProduct param,HttpSession session) { System.out.print(Json.toJson(param)); UserObject user=(UserObject)session.getAttribute("userObject"); param.setUsrModify(user.getUserId()); param.setOrgModify(user.getUserOrgName()); param.setDatModify(new Timestamp(System.currentTimeMillis())); ExecuteState state = productCfgManagerBiz.updateProductCfg(param); return state; } ``` 现在如果在param参数中有特殊字符,那么我将定义 web.xml,代码如下 ``` <filter> <filter-name>XssFilter</filter-name> <filter-class>com.ifs.frame.filter.XssFilter</filter-class> </filter> <filter-mapping> <filter-name>XssFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 拦截器代码 ``` public class XssFilter implements Filter { FilterConfig filterConfig = null; public void doFilter(ServletRequest request, ServletResponse response, FilterChain filterChain) throws IOException, ServletException { XssHttpServletRequestWrapper xssRequest = new XssHttpServletRequestWrapper( (HttpServletRequest) request); filterChain.doFilter(xssRequest, response); } @Override public void init(FilterConfig filterConfig) throws ServletException { this.filterConfig = filterConfig; } @Override public void destroy() { this.filterConfig=null; } } ``` XssHttpServletRequestWrapper代码 ``` public class XssHttpServletRequestWrapper extends HttpServletRequestWrapper { public XssHttpServletRequestWrapper(HttpServletRequest servletRequest) { super(servletRequest); } public String[] getParameterValues(String parameter) { String[] values = super.getParameterValues(parameter); if (values==null) { return null; } int count = values.length; String[] encodedValues = new String[count]; for (int i = 0; i < count; i++) { encodedValues[i] = cleanXSS(values[i]); } return encodedValues; } public String getParameter(String parameter) { String value = super.getParameter(parameter); if (value == null) { return null; } return cleanXSS(value); } public String getHeader(String name) { String value = super.getHeader(name); if (value == null) return null; return cleanXSS(value); } private String cleanXSS(String value) { value = value.replaceAll("&", "&amp;"); value = value.replaceAll("#", "&#35;"); value = value.replaceAll("<", "&lt;").replaceAll(">", "&gt;"); value = value.replaceAll("\"", "&#92;"); value = value.replaceAll("'", "&#39;"); return value; } ``` 现在这些代码我确无法获取到data中的值,也无法转换,各位有什么好的解决方法吗? 以我现在所知道的是参数未封装到HttpServletRequest里面导致的。但我现在无法在来修改源码了,也只有通过写过滤器来想办法
web.xml基本配置代表的含义
这个配置里<init-param></init-param>里面的两行代表什么意思,还有就是<filter-mapping></filter-mapping>中过滤器拦截名称是什么作用,可以随便取吗?拦截所有.action用户的请求怎么理解(主要是这个.action不懂),最后下面为何又出现了一组<filter-mapping></filter-mapping>,这又代表什么意思![图片说明](http://img.bbs.csdn.net/upload/201603/16/1458127022_223365.png)
spring security3拦截器问题
未登录系统的情况下,第一次访问页面会跳转到登录页面,第二次访问就能够访问 配置如下: ``` <http entry-point-ref="loginAuthenticationEntryPoint" > <!-- UsernamePasswordAuthenticationFilter default-target-url 指定了从登录页面登录后进行跳转的页面 always-use-default-target true表示登录成功后强制跳转 authentication-failure-url 表示验证失败后进入的页面 login-processing-url 设置验证登录验证地址,如果不设置,默认是j_spring_security_check username-parameter,password-parameter 设置登录用户名和密码的请求name,默认:j_username,j_password <form-login login-page="/login" default-target-url="/index" authentication-failure-url="/login?error=1" login-processing-url="/logined" username-parameter="loginUser" password-parameter="password" /> --> <logout logout-success-url="/login" invalidate-session="true" delete-cookies="JSESSIONID"/> <!-- 尝试访问没有权限的页面时跳转的页面 --> <access-denied-handler error-page="/permission" /> <!-- session-fixation-protection session固化保护 none使得 session 固化攻击失效,不会配置 SessionManagementFilter (除非其它的 <session-management> 属性不是默认值) migrateSession当用户经过认证后分配一个新的 session ,它保证原 session 的所有属性移到新 session 中。我们将在后面的章节中讲解,通过基于 bean 的方式如何进行这样的配置。 newSession当用户认证后,建立一个新的 session ,原(未认证时) session 的属性不会进行移到新 session 中来。--> <session-management invalid-session-url="/login" session-authentication-strategy-ref="compositeSessionAuthenticationStrategy" /> <custom-filter position="FORM_LOGIN_FILTER" ref="formloginFilter" /> <custom-filter position="CONCURRENT_SESSION_FILTER" ref="concurrencyFilter" /> <!-- 增加一个filter,这点与 Acegi是不一样的,不能修改默认的filter了, 这个filter位于FILTER_SECURITY_INTERCEPTOR之前 --> <custom-filter before="FILTER_SECURITY_INTERCEPTOR" ref="myFilter" /> </http> <!-- ConcurrentSessionFilter过滤器配置(主要设置账户session过期路径) 并发会话处理包所需要的过滤器。该过滤器具有双重作用。 首先,它会调用sessionregistry.refreshlastrequest为每个请求注册session总是有一个正确的最后更新时间。 第二,它会为每个请求从sessionregistry中获取sessioninformation并且检查session是否已被标记为已过期。 如果它被标记为已过期,配置注销处理程序将被调用(如同logoutfilter),重定向到指定的expiredurl,session失效将导致httpsessiondestroyedevent被触发 通过在web.xml注册httpsessioneventpublisher。 --> <beans:bean id="concurrencyFilter" class="org.springframework.security.web.session.ConcurrentSessionFilter"> <beans:property name="sessionRegistry" ref="sessionRegistry" /> <beans:property name="expiredUrl" value="/login" /> </beans:bean> <!-- 登录过滤器(相当于<form-login/>) --> <beans:bean id="formloginFilter" class="org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter"> <beans:property name="usernameParameter" value="loginUser"></beans:property> <beans:property name="passwordParameter" value="password"></beans:property> <beans:property name="sessionAuthenticationStrategy" ref="compositeSessionAuthenticationStrategy" /> <!--处理登录的action --> <beans:property name="filterProcessesUrl" value="/logined"></beans:property> <!--验证成功后的处理 --> <beans:property name="authenticationSuccessHandler" ref="loginLogAuthenticationSuccessHandler"></beans:property> <!--验证失败后的处理 --> <beans:property name="authenticationFailureHandler" ref="simpleUrlAuthenticationFailureHandler"></beans:property> <beans:property name="authenticationManager" ref="authenticationManager"></beans:property> </beans:bean> <!-- 混合session授权策略 --> <beans:bean id="compositeSessionAuthenticationStrategy" class="org.springframework.security.web.authentication.session.CompositeSessionAuthenticationStrategy"> <beans:constructor-arg> <beans:list> <beans:bean class="org.springframework.security.web.authentication.session.ConcurrentSessionControlAuthenticationStrategy"> <beans:constructor-arg ref="sessionRegistry" /> <beans:property name="maximumSessions" value="1" /> <beans:property name="exceptionIfMaximumExceeded" value="true" /> </beans:bean> <beans:bean class="org.springframework.security.web.authentication.session.SessionFixationProtectionStrategy"> </beans:bean> <beans:bean class="org.springframework.security.web.authentication.session.RegisterSessionAuthenticationStrategy"> <beans:constructor-arg ref="sessionRegistry" /> </beans:bean> </beans:list> </beans:constructor-arg> </beans:bean> <!--SessionRegistry的默认实现,它会在spring应用上下文中监听SessionDestroyedEvents事件 --> <beans:bean id="sessionRegistry" class="org.springframework.security.core.session.SessionRegistryImpl" /> <!-- 登录点 --> <beans:bean id="loginAuthenticationEntryPoint" class="org.springframework.security.web.authentication.LoginUrlAuthenticationEntryPoint"> <beans:property name="loginFormUrl" value="/login"></beans:property> </beans:bean> <!-- 验证成功后的处理 --> <beans:bean id="loginLogAuthenticationSuccessHandler" class="org.springframework.security.web.authentication.SavedRequestAwareAuthenticationSuccessHandler"> <beans:property name="defaultTargetUrl" value="/index"></beans:property> </beans:bean> <!-- 验证失败后的处理 --> <beans:bean id="simpleUrlAuthenticationFailureHandler" class="org.springframework.security.web.authentication.SimpleUrlAuthenticationFailureHandler"> <!--可以配置相应的跳转方式。属性forwardToDestination为true采用forward false为sendRedirect --> <beans:property name="defaultFailureUrl" value="/login?error=1"></beans:property> </beans:bean> <!-- 一个自定义的filter,必须包含 authenticationManager,accessDecisionManager,securityMetadataSource三个属性, 我们的所有控制将在这三个类中实现,解释详见具体配置 --> <beans:bean id="myFilter" class="com.sanchuan.erp.security.MyFilterSecurityInterceptor"> <beans:property name="authenticationManager" ref="authenticationManager" /> <beans:property name="accessDecisionManager" ref="myAccessDecisionManagerBean" /> <beans:property name="securityMetadataSource" ref="mySecurityMetadataSource" /> </beans:bean> <!-- 验证配置 , 认证管理器,实现用户认证的入口,主要实现UserDetailsService接口即可 --> <authentication-manager alias="authenticationManager"> <authentication-provider user-service-ref="myUserDetailsService"> <!-- <s:password-encoder hash="sha" /> --> </authentication-provider> </authentication-manager> <!-- 项目实现的用户查询服务,将用户信息查询出来 --> <beans:bean id="myUserDetailsService" class="com.sanchuan.erp.security.MyUserDetailService"> <beans:property name="userService" ref="userServiceImpl"></beans:property> <beans:property name="roleService" ref="roleServiceImpl"></beans:property> </beans:bean> <!-- 访问决策器,决定某个用户具有的角色,是否有足够的权限去访问某个资源 --> <beans:bean id="myAccessDecisionManagerBean" class="com.sanchuan.erp.security.MyAccessDecisionManager"> </beans:bean> <!-- 资源源数据定义,将所有的资源和权限对应关系建立起来,即定义某一资源可以被哪些角色访问 --> <beans:bean id="mySecurityMetadataSource" class="com.sanchuan.erp.security.MyInvocationSecurityMetadataSourceService"> </beans:bean> ```
Filter 过滤一段请求,如果不需要对请求进行操作,让其正常访问这个请求要怎么做
可能标题我叙述的不清楚,一个jsp请求被拦截,判断cookie里有没有数据。如果cookie里没有数据,则继续访问这个jsp,这个要怎么做呢? if(cookieValue == null){ 。。。。。。。。。 }
SSH的项目中有没有判断session是否为空的过滤器之类的东西
SSH的项目中,如何统一判断session是否为空,项目中很多操作都需要登录后才能执行,不想在每个action中都写判断session是否为空的语句,有没有什么拦截器,或者spring的什么配置可以搞定这个的? [b]问题补充:[/b] 写了个struts2 的拦截器,代码如下: @Override public String intercept(ActionInvocation arg0) throws Exception { Logger logger = Logger.getLogger(this.getClass()); // TODO Auto-generated method stub Corp corp = (Corp)ActionContext.getContext().getSession().get("corp"); if(corp==null){ logger.info("strus 拦截器 corp 为空"); return "none"; } logger.info("struts 拦截器 invoke:返回"+arg0.invoke()); return arg0.invoke(); } 结果出现了个异常如下: java.lang.IllegalStateException at org.apache.catalina.connector.ResponseFacade.sendError(ResponseFacade.java:407) at org.apache.struts2.dispatcher.Dispatcher.sendError(Dispatcher.java:725) at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:485) at org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77) at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:76) at com.cool.filter.MyFilter.doFilter(MyFilter.java:61) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.apache.struts2.dispatcher.ActionContextCleanUp.doFilter(ActionContextCleanUp.java:102) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at com.cool.filter.MyCharacterEncodingFilter.doFilterInternal(MyCharacterEncodingFilter.java:58) at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76) at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235) at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233) at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128) at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:263) at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844) at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:584) at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447) at java.lang.Thread.run(Unknown Source) [b]问题补充:[/b] 哪个能帮忙搞定,不明白为什么会和struts2的过滤器相关,myfilter是我自己的过滤器,集成struts2的过滤器。试过了只要去掉拦截器就不会出现这个错误。 [b]问题补充:[/b] 蔡华江同学,还是一样的错误哦,这个和session没有什么关系吧,网上都说是调用了两次response,我很费解,如果没有登录返回none的时候没有错误,登录后session不为空了反倒出了这个错误,你再帮我看看吧,我实在搞不定了,我看好你哦。
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小人工智障。 思路可以运用在不同地方,主要介绍的是思路。
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
阿里面试官问我:如何设计秒杀系统?我的回答让他比起大拇指
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图和个人联系方式,欢迎Star和指教 前言 Redis在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在Redis的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸,打败了...
C语言魔塔游戏
很早就很想写这个,今天终于写完了。 游戏截图: 编译环境: VS2017 游戏需要一些图片,如果有想要的或者对游戏有什么看法的可以加我的QQ 2985486630 讨论,如果暂时没有回应,可以在博客下方留言,到时候我会看到。 下面我来介绍一下游戏的主要功能和实现方式 首先是玩家的定义,使用结构体,这个名字是可以自己改变的 struct gamerole { char n...
面试官问我:什么是消息队列?什么场景需要他?用了会出现什么问题?
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Android性能优化(4):UI渲染机制以及优化
文章目录1. 渲染机制分析1.1 渲染机制1.2 卡顿现象1.3 内存抖动2. 渲染优化方式2.1 过度绘制优化2.1.1 Show GPU overdraw2.1.2 Profile GPU Rendering2.2 卡顿优化2.2.1 SysTrace2.2.2 TraceView 在从Android 6.0源码的角度剖析View的绘制原理一文中,我们了解到View的绘制流程有三个步骤,即m...
微服务中的Kafka与Micronaut
今天,我们将通过Apache Kafka主题构建一些彼此异步通信的微服务。我们使用Micronaut框架,它为与Kafka集成提供专门的库。让我们简要介绍一下示例系统的体系结构。我们有四个微型服务:订单服务,行程服务,司机服务和乘客服务。这些应用程序的实现非常简单。它们都有内存存储,并连接到同一个Kafka实例。 我们系统的主要目标是为客户安排行程。订单服务应用程序还充当网关。它接收来自客户的请求...
致 Python 初学者们!
作者| 许向武 责编 | 屠敏 出品 | CSDN 博客 前言 在 Python 进阶的过程中,相信很多同学应该大致上学习了很多 Python 的基础知识,也正在努力成长。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 Python 这门编程语言,从2009年开始单一使用 Python 应对所有的开发工作,直至今...
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip installselenium -ihttps://pypi.tuna.tsinghua.edu.cn/simple/ ...
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
Java工作4年来应聘要16K最后没要,细节如下。。。
前奏: 今天2B哥和大家分享一位前几天面试的一位应聘者,工作4年26岁,统招本科。 以下就是他的简历和面试情况。 基本情况: 专业技能: 1、&nbsp;熟悉Sping了解SpringMVC、SpringBoot、Mybatis等框架、了解SpringCloud微服务 2、&nbsp;熟悉常用项目管理工具:SVN、GIT、MAVEN、Jenkins 3、&nbsp;熟悉Nginx、tomca...
SpringBoot2.x系列教程(三十六)SpringBoot之Tomcat配置
Spring Boot默认内嵌的Tomcat为Servlet容器,关于Tomcat的所有属性都在ServerProperties配置类中。同时,也可以实现一些接口来自定义内嵌Servlet容器和内嵌Tomcat等的配置。 关于此配置,网络上有大量的资料,但都是基于SpringBoot1.5.x版本,并不适合当前最新版本。本文将带大家了解一下最新版本的使用。 ServerProperties的部分源...
Python绘图,圣诞树,花,爱心 | Turtle篇
每周每日,分享Python实战代码,入门资料,进阶资料,基础语法,爬虫,数据分析,web网站,机器学习,深度学习等等。 公众号回复【进群】沟通交流吧,QQ扫码进群学习吧 微信群 QQ群 1.画圣诞树 import turtle screen = turtle.Screen() screen.setup(800,600) circle = turtle.Turtle()...
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东...
破14亿,Python分析我国存在哪些人口危机!
一、背景 二、爬取数据 三、数据分析 1、总人口 2、男女人口比例 3、人口城镇化 4、人口增长率 5、人口老化(抚养比) 6、各省人口 7、世界人口 四、遇到的问题 遇到的问题 1、数据分页,需要获取从1949-2018年数据,观察到有近20年参数:LAST20,由此推测获取近70年的参数可设置为:LAST70 2、2019年数据没有放上去,可以手动添加上去 3、将数据进行 行列转换 4、列名...
听说想当黑客的都玩过这个Monyer游戏(1~14攻略)
第零关 进入传送门开始第0关(游戏链接) 请点击链接进入第1关: 连接在左边→ ←连接在右边 看不到啊。。。。(只能看到一堆大佬做完的留名,也能看到菜鸡的我,在后面~~) 直接fn+f12吧 &lt;span&gt;连接在左边→&lt;/span&gt; &lt;a href="first.php"&gt;&lt;/a&gt; &lt;span&gt;←连接在右边&lt;/span&gt; o...
在家远程办公效率低?那你一定要收好这个「在家办公」神器!
相信大家都已经收到国务院延长春节假期的消息,接下来,在家远程办公可能将会持续一段时间。 但是问题来了。远程办公不是人在电脑前就当坐班了,相反,对于沟通效率,文件协作,以及信息安全都有着极高的要求。有着非常多的挑战,比如: 1在异地互相不见面的会议上,如何提高沟通效率? 2文件之间的来往反馈如何做到及时性?如何保证信息安全? 3如何规划安排每天工作,以及如何进行成果验收? ...... ...
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!...
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
2020年全新Java学习路线图,含配套视频,学完即为中级Java程序员!!
新的一年来临,突如其来的疫情打破了平静的生活! 在家的你是否很无聊,如果无聊就来学习吧! 世上只有一种投资只赚不赔,那就是学习!!! 传智播客于2020年升级了Java学习线路图,硬核升级,免费放送! 学完你就是中级程序员,能更快一步找到工作! 一、Java基础 JavaSE基础是Java中级程序员的起点,是帮助你从小白到懂得编程的必经之路。 在Java基础板块中有6个子模块的学...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
爬取薅羊毛网站百度云资源
这是疫情期间无聊做的爬虫, 去获取暂时用不上的教程 import threading import time import pandas as pd import requests import re from threading import Thread, Lock # import urllib.request as request # req=urllib.request.Requ...
如何优雅地打印一个Java对象?
你好呀,我是沉默王二,一个和黄家驹一样身高,和刘德华一样颜值的程序员。虽然已经写了十多年的 Java 代码,但仍然觉得自己是个菜鸟(请允许我惭愧一下)。 在一个月黑风高的夜晚,我思前想后,觉得再也不能这么蹉跎下去了。于是痛下决心,准备通过输出的方式倒逼输入,以此来修炼自己的内功,从而进阶成为一名真正意义上的大神。与此同时,希望这些文章能够帮助到更多的读者,让大家在学习的路上不再寂寞、空虚和冷。 ...
雷火神山直播超两亿,Web播放器事件监听是怎么实现的?
Web播放器解决了在手机浏览器和PC浏览器上播放音视频数据的问题,让视音频内容可以不依赖用户安装App,就能进行播放以及在社交平台进行传播。在视频业务大数据平台中,播放数据的统计分析非常重要,所以Web播放器在使用过程中,需要对其内部的数据进行收集并上报至服务端,此时,就需要对发生在其内部的一些播放行为进行事件监听。 那么Web播放器事件监听是怎么实现的呢? 01 监听事件明细表 名...
3万字总结,Mysql优化之精髓
本文知识点较多,篇幅较长,请耐心学习 MySQL已经成为时下关系型数据库产品的中坚力量,备受互联网大厂的青睐,出门面试想进BAT,想拿高工资,不会点MySQL优化知识,拿offer的成功率会大大下降。 为什么要优化 系统的吞吐量瓶颈往往出现在数据库的访问速度上 随着应用程序的运行,数据库的中的数据会越来越多,处理时间会相应变慢 数据是存放在磁盘上的,读写速度无法和内存相比 如何优化 设计...
HTML5适合的情人节礼物有纪念日期功能
前言 利用HTML5,css,js实现爱心树 以及 纪念日期的功能 网页有播放音乐功能 以及打字倾诉感情的画面,非常适合情人节送给女朋友 具体的HTML代码 具体只要修改代码里面的男某某和女某某 文字段也可自行修改,还有代码下半部分的JS代码需要修改一下起始日期 注意月份为0~11月 也就是月份需要减一。 当然只有一部分HTML和JS代码不够运行的,文章最下面还附加了完整代码的下载地址 &lt;!...
相关热词 c# 数组类型 泛型约束 c#的赛狗日程序 c# 传递数组 可变参数 c# 生成存储过程 c# list 补集 c#获得所有窗体 c# 当前秒数转成年月日 c#中的枚举 c# 计算校验和 连续随机数不重复c#
立即提问