- ServletConfig && ServletContext
Code溪
java前端服务器
一.ServletConfig1.Servlet1代码@WebServlet(urlPatterns="servlet1",initParams={@WebInitParam(name="keya",value="valueA")})publicclassServlet1extendsHttpServlet{@Overrideprotectedvoidservice(HttpServletRequ
- 【JavaWeb】Servlet系列——session会话机制
胖虎不秃头
JavaWebservletjava前端
文章目录29关于B/S结构系统的会话机制(session机制)29.1关于会话29.2为什么需要session对象来保存会话状态呢?29.3为什么不使用request对象保存会话状态?为什么不使用ServletContext对象保存会话状态?29.4session对象的实现原理。29.5Cookie禁用29.6域对象:29.7解决oa项目中的登录问题,让登录起作用。29.8会话结束29.9销毁se
- spring4第6课-bean之间的关系+bean的作用范围
ademen
springjavaspring
总结:①bean之间的关系有1,继承;2,依赖;3,引用;②bean的作用范围(scope)1,singletonSpringioc容器中仅有一个Bean实例,Bean以单例的方式存在;(重点)2,prototype每次从容器中调用Bean时,都返回一个新的实例;(重点)3,request每次HTTP请求都会创建一个新的Bean;4,session同一个HTTPSession共享一个Bean;5,
- Java Spring 之监听器(Listener)详解与实战
Java皇帝
javaspringjavaspring后端开发语言
目录一、监听器的作用1.1应用生命周期管理1.2会话管理1.3请求处理监控二、创建监听器2.1Servlet容器监听器2.2HttpSession监听器2.3请求处理监听器三、Spring应用事件监听器3.1定义自定义事件3.2创建事件监听器3.3发布事件四、总结在Spring框架中,监听器(Listener)是一种用于监听特定事件的强大工具。通过监听器,我们可以在事件发生时执行自定义的逻辑,例如
- Spring 中 Bean 的作用域有哪些?默认是什么?
_艾米莉
springjava后端学习开发语言算法负载均衡
分析:Spring支持6种作用域(Bean的创建和销毁范围),需结合依赖注入场景理解。singleton:默认作用域,容器中仅创建一个实例,全局共享(如服务层Bean)。prototype:每次请求都会创建新实例(如资源消耗大的Bean)。request:一次HTTP请求内有效(需结合Web环境,如SpringMVC)。session:同一个HTTPSession内有效。application:同
- Springboot 项目一启动就获取HttpSession
梁云亮
SpringBootspringboot获取Session
在SpringBoot项目中,HttpSession是有状态的,通常只有在用户发起HTTP请求并建立会话后才会创建。因此,在项目启动时(即应用刚启动还未处理任何请求)是无法获取到HttpSession的。方法一:使用HttpSessionListener(监听session创建)@ComponentpublicclassMySessionListenerimplementsHttpSessionL
- ServletContext 接口:Java Web——补充
magic 245
JavaWeb#Servletjava前端开发语言
一、引言在JavaWeb开发中,ServletContext是一个核心概念,它代表了Web应用本身。通过ServletContext,不同的Servlet组件可以共享数据、访问应用资源,并且与Web服务器进行交互。本文将深入探讨ServletContext接口的作用、功能及其在实际开发中的应用场景。二、ServletContext接口概述1.定义与作用ServletContext是Servlet规
- Web会话机制全景深度概览
北漂老男人
web会话机制笔记经验分享
一、Web会话机制概览Web会话机制用于追踪和识别用户的连续操作,常见于登录、购物车、权限管理等场景。主流方案有:CookieURL重写隐藏表单域HttpSession分布式Session(如SpringSession/Redis)Token机制(JWT、OAuth2、OpenIDConnect)前后端分离的Token+API网关SSO(单点登录,CAS、SAML、OIDC)二、主流会话机制技术栈
- servlet-api
xlsw_
servlet
本次内容总结1、再次学习Servlet的初始化方法2、学习Servlet中的ServletContext和3、什么是业务层4、IOC5、过滤器7、TransActionManager、ThreadLocal、OpenSessionInViewFilter1、再次学习Servlet的初始化方法1)Servlet生命周期:实例化、初始化、服务、销毁。2)Servletz中的初始化方法有两个:init(
- HttpSession背景、使用原理、使用环境、生命周期
小兜熊
HttpSession
导语:目前所写项目遇到几个问题:前后端分离下如何验证用户身份、用户登录后如何持久化,虽用cookie解决,但在编写过程中深感代码效率低下,希望寻求更高优质的解决思路,深入了解一下Session的背景、使用原理、使用环境。1、http协议:简单了解一下http协议可以更好理解session机制http协议是“连接-请求-应答-关闭连接”模式,是一种无状态协议(http只是一个传输协议)因为http是
- Spring MVC Session 属性 (@SessionAttributes) 是什么?如何使用它共享数据?
冰糖心书房
SpringMVC源码系列springmvcjava
在SpringMVC中,@SessionAttributes是一个类级别的注解,用于表示SpringMVC将Controller中的属性存储到HTTPSession中,以便在同一用户会话的后续请求中可以访问这些属性。简单来说,它的作用是将请求范围的模型(Model)属性“提升”到会话范围。为什么需要@SessionAttributes?模型属性(通过Model,ModelMap,ModelAndV
- HttpSessionAttributeListener 的用法笔记250417
kfepiza
JAVA笔记javatomcatservletjava-eespringboot
HttpSessionAttributeListener的用法笔记250417以下是关于HttpSessionAttributeListener的用法详解,涵盖核心方法、应用场景、实现步骤及关键注意事项,帮助您有效监听会话(HttpSession)中属性的动态变化:1.核心功能HttpSessionAttributeListener用于监听会话(HttpSession)中属性的增删改事件,适用于实
- servletcontext的作用详细介绍
时光旅人01号
Javawebservlettomcatjavaweb.xmlhttp
1、什么是servletcontextweb容器在启动的时候,他会为每个web程序创建一个对应的servletcontext对象,他代表的是当前的web应用:共享数据我在这个Servlet中保存的数据,可以在宁一个servlet中拿到:例子如下设置数据publicclassServlettestextendsHttpServlet{protectedvoiddoPost(HttpServletRe
- java中过滤器应实现的接口_下面选项中,编写过滤器需要实现的接口是( )
凛冬之怒
java中过滤器应实现的接口
【填空题】Tomcat容器中会话的有效时间可以在___文件中设置,默认会话过期时间为30分钟【判断题】在修改传智书城注册页面使用include指令包含顶部、菜单列表和底部这些公共页面时,可以参考引入css、js文件一样放到head标签内部。()【单选题】下列选项中,可以更改Cookie的存活时间的是()【判断题】用于监听HttpSession对象生命周期的接口是HttpSessionBinding
- 大模型GPT辅助学习解释代码-HttpSession 监听器
ahauedu
前沿技术与趋势gpt
本文主题大模型解释代码。最近在接触旧项目代码是往往没有注释,或者是注释和代码对应不上,这样对于了解业务逻辑,以及后期的改造开发造成了很大的困扰。尽然大模型这么强大,我们尝试下用大模型来解释代码。以下是大模型对项目代码中的HttpSession监听器的代码解释,很高效的方式,可以借鉴。代码解析这段代码定义了WebHttpSessionListener类,它是一个HttpSession监听器,用于监听
- Web 应用中 HttpSession 的工作原理
triticale
前端java开发语言
首次访问:当浏览器A和浏览器B首次访问Web服务器时,服务器通过request.getSession()方法为每个浏览器创建一个HttpSession对象,并生成对应的jsessionid。该jsessionid通过Cookie响应给浏览器,用于标识会话。第二次访问:后续浏览器再次发起请求时,会携带jsessionid。服务器根据该jsessionid在HttpSession列表(Map)中找到对
- Spring MVC中使用HttpSession管理会话属性
t0_54program
数据库个人开发
在SpringMVC开发中,我们常常需要处理用户会话(Session)相关的数据。虽然Spring提供了SessionScope的Bean来管理会话数据,但在某些情况下,我们可能无法使用这种方式。这时,我们可以借助低级别的ServletAPI来实现会话管理。本文将通过一个具体的实例,展示如何在SpringMVC控制器中使用javax.servlet.http.HttpSession来管理会话属性。
- Java(Springboot)
奶龙牛牛
javaspringboot开发语言
get请求在Controller中--->从仓库里取出要用的mysql----->对于get请求(httpsession,model容器)----->从httpsession取出userid再赋值给userid----->用userid在mysql获取用户的信息------>然后用户的信息在保存在model容器里---->return到html地址里面put请求得到请求体的参数--->从https
- Java Web:项目结构和web.xml
weixin_33827965
javaweb.xml
结构:web.xml:testindex.htmltestservlet.Controller/pages/test.jsptest_initParaminitParam--163.comtest/testtest-contextParamcontextParam--hotmail.comlistener.TestListener每一个web应用只有一个ServletContext(分布式环境中,
- 生成验证码的工具类
落晚_
java
packagecom.htc.utils;importorg.springframework.stereotype.Component;importjavax.imageio.ImageIO;importjavax.servlet.http.HttpServletResponse;importjavax.servlet.http.HttpSession;importjava.awt.*;impor
- webSocket获取httpsession
爱吃辣椒炒肉
javawebsocketsession
websocket使用握手拦截器publicclassHttpSessionHandshakeInterceptorextendsorg.springframework.web.socket.server.support.HttpSessionHandshakeInterceptor{@OverridepublicbooleanbeforeHandshake(ServerHttpRequestre
- JavaWeb,会话管理的学习
曦月落雨
javaWebjavaweb
会话管理概述无状态协议无状态就是不保存状态,HTTP就是无状态协议,HTTP协议自身不会对请求和响应之间的通信状态进行保存,也就是说,在HTTP协议这个级别,协议对于发送过的请求或者响应都不做持久化处理。会话管理实现的手段cookie是在客户端保留少量数据的技术,主要通过响应头向客户端响应一些客户端要保留的信息session是在服务器端保留更多的数据的技术,主要通过HttpSession对象保存一
- idea处理文件报错问题
大cheng
idea处理文件报错问题1、idea上传文件获取文件路径的报错报错原因:ServletRequest的getServletContext方法是Servlet3.0添加的,本地用的是Tomcat9.0,版本比较高,支持request.getServletContext()这种写法,而线上是Tomcat6.0,只支持到Servlet2.5,需要先用request拿到HttpSession或者通过Ser
- jsp有哪些内置对象?作用分别是什么?
富哥92
面试
1.HttpServletRequet类的Request对象:代表请求对象,主要用于接受客户端通过HTTP协议连接传输服务器端的数据。2.HttpSevletResponse类的Response对象:代表响应对象,主要用于向客户端发送数据。3.JspWriter类的out对象:主要用于向客户端输出数据,out的基类是jspWriter4.HttpSession类的session对象:主要用来分别保
- web.xml and server.xml-03-11
封_绝
web.xml加载顺序:ServletContext→context-param→listener→filter→servletserver.xmlAJP服务器群集热部署:不需要每次做修改都重启服务器,//下//如果该路径下没有项目,则会报错(其余项目依旧会正常加载),如果是使用冷部署则不会报错?idea中的设置如下:image.png
- SpringMVC参数解析器HandlerMethodArgumentResolver
这是一条海鱼
SpringMVC
前言在享受SpringMVC带给你便捷的时候,你是否曾经这样疑问过:Controller的handler方法参数能够自动完成参数封装(有时即使没有@PathVariable、@RequestParam、@RequestBody等注解都可),甚至在方法参数任意位置写HttpServletRequest、HttpSession、Writer…等类型的参数,它自动就有值了便可直接使用。对此你是否想问一句
- 分布式 WebSocket 集群解决方案
2401_83916394
程序员分布式websocket网络协议
下面我将描述session特性,以及根据这些特性列举出n个解决分布式架构中处理ws请求的集群方案WebSocketSession与HttpSession在Spring所集成的WebSocket里面,每个ws连接都有一个对应的session:WebSocketSession,在SpringWebSocket中,我们建立ws连接之后可以通过类似这样的方式进行与客户端的通信:protectedvoidh
- java servletcontext 获得路径_ServletContext获取项目真实路径
天接云涛
javaservletcontext获得路径
importjavax.servlet.ServletContext;importorg.springframework.web.context.ServletContextAware;/***@authorAdministrator**/publicclassPayUtilimplementsServletContextAware{publicServletContextcontext;publ
- JavaEE学习day-49:Servlet技术综合训练
开源oo柒
一、ServletContext和ServletConfig1.ServletContext对象:解决的问题:Request解决了一次请求内的数据共享问题,session解决了用户不同请求的数据共享问题,ServletContext解决了不同的用户的数据共享。原理:ServletContext对象由服务器进行创建,一个项目只有一个对象。不管在项目的任意位置进行获取得到的都是同一个对象,那么不同用户
- 黑猴子的家:JavaWeb 之 Servlet Listener 监听器
黑猴子的家
1、监听器简介Listener是JavaWeb中三大组件之一。Servlet、Filter、Listener三大组件都有的共同特点,都需要实现一个接口,并在web.xml文件配置。JavaWeb中的监听器的监听对象是谁? ServletContext HttpSession ServletRequest2、监听器分类JavaWeb中的监听器共有三种,共8个监听器 -生命周期
- 如何用ruby来写hadoop的mapreduce并生成jar包
wudixiaotie
mapreduce
ruby来写hadoop的mapreduce,我用的方法是rubydoop。怎么配置环境呢:
1.安装rvm:
不说了 网上有
2.安装ruby:
由于我以前是做ruby的,所以习惯性的先安装了ruby,起码调试起来比jruby快多了。
3.安装jruby:
rvm install jruby然后等待安
- java编程思想 -- 访问控制权限
百合不是茶
java访问控制权限单例模式
访问权限是java中一个比较中要的知识点,它规定者什么方法可以访问,什么不可以访问
一:包访问权限;
自定义包:
package com.wj.control;
//包
public class Demo {
//定义一个无参的方法
public void DemoPackage(){
System.out.println("调用
- [生物与医学]请审慎食用小龙虾
comsci
生物
现在的餐馆里面出售的小龙虾,有一些是在野外捕捉的,这些小龙虾身体里面可能带有某些病毒和细菌,人食用以后可能会导致一些疾病,严重的甚至会死亡.....
所以,参加聚餐的时候,最好不要点小龙虾...就吃养殖的猪肉,牛肉,羊肉和鱼,等动物蛋白质
- org.apache.jasper.JasperException: Unable to compile class for JSP:
商人shang
maven2.2jdk1.8
环境: jdk1.8 maven tomcat7-maven-plugin 2.0
原因: tomcat7-maven-plugin 2.0 不知吃 jdk 1.8,换成 tomcat7-maven-plugin 2.2就行,即
<plugin>
- 你的垃圾你处理掉了吗?GC
oloz
GC
前序:本人菜鸟,此文研究学习来自网络,各位牛牛多指教
1.垃圾收集算法的核心思想
Java语言建立了垃圾收集机制,用以跟踪正在使用的对象和发现并回收不再使用(引用)的对象。该机制可以有效防范动态内存分配中可能发生的两个危险:因内存垃圾过多而引发的内存耗尽,以及不恰当的内存释放所造成的内存非法引用。
垃圾收集算法的核心思想是:对虚拟机可用内存空间,即堆空间中的对象进行识别
- shiro 和 SESSSION
杨白白
shiro
shiro 在web项目里默认使用的是web容器提供的session,也就是说shiro使用的session是web容器产生的,并不是自己产生的,在用于非web环境时可用其他来源代替。在web工程启动的时候它就和容器绑定在了一起,这是通过web.xml里面的shiroFilter实现的。通过session.getSession()方法会在浏览器cokkice产生JESSIONID,当关闭浏览器,此
- 移动互联网终端 淘宝客如何实现盈利
小桔子
移動客戶端淘客淘寶App
2012年淘宝联盟平台为站长和淘宝客带来的分成收入突破30亿元,同比增长100%。而来自移动端的分成达1亿元,其中美丽说、蘑菇街、果库、口袋购物等App运营商分成近5000万元。 可以看出,虽然目前阶段PC端对于淘客而言仍旧是盈利的大头,但移动端已经呈现出爆发之势。而且这个势头将随着智能终端(手机,平板)的加速普及而更加迅猛
- wordpress小工具制作
aichenglong
wordpress小工具
wordpress 使用侧边栏的小工具,很方便调整页面结构
小工具的制作过程
1 在自己的主题文件中新建一个文件夹(如widget),在文件夹中创建一个php(AWP_posts-category.php)
小工具是一个类,想侧边栏一样,还得使用代码注册,他才可以再后台使用,基本的代码一层不变
<?php
class AWP_Post_Category extends WP_Wi
- JS微信分享
AILIKES
js
// 所有功能必须包含在 WeixinApi.ready 中进行
WeixinApi.ready(function(Api) {
// 微信分享的数据
var wxData = {
&nb
- 封装探讨
百合不是茶
JAVA面向对象 封装
//封装 属性 方法 将某些东西包装在一起,通过创建对象或使用静态的方法来调用,称为封装;封装其实就是有选择性地公开或隐藏某些信息,它解决了数据的安全性问题,增加代码的可读性和可维护性
在 Aname类中申明三个属性,将其封装在一个类中:通过对象来调用
例如 1:
//属性 将其设为私有
姓名 name 可以公开
- jquery radio/checkbox change事件不能触发的问题
bijian1013
JavaScriptjquery
我想让radio来控制当前我选择的是机动车还是特种车,如下所示:
<html>
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js" type="text/javascript"><
- AngularJS中安全性措施
bijian1013
JavaScriptAngularJS安全性XSRFJSON漏洞
在使用web应用中,安全性是应该首要考虑的一个问题。AngularJS提供了一些辅助机制,用来防护来自两个常见攻击方向的网络攻击。
一.JSON漏洞
当使用一个GET请求获取JSON数组信息的时候(尤其是当这一信息非常敏感,
- [Maven学习笔记九]Maven发布web项目
bit1129
maven
基于Maven的web项目的标准项目结构
user-project
user-core
user-service
user-web
src
- 【Hive七】Hive用户自定义聚合函数(UDAF)
bit1129
hive
用户自定义聚合函数,用户提供的多个入参通过聚合计算(求和、求最大值、求最小值)得到一个聚合计算结果的函数。
问题:UDF也可以提供输入多个参数然后输出一个结果的运算,比如加法运算add(3,5),add这个UDF需要实现UDF的evaluate方法,那么UDF和UDAF的实质分别究竟是什么?
Double evaluate(Double a, Double b)
- 通过 nginx-lua 给 Nginx 增加 OAuth 支持
ronin47
前言:我们使用Nginx的Lua中间件建立了OAuth2认证和授权层。如果你也有此打算,阅读下面的文档,实现自动化并获得收益。SeatGeek 在过去几年中取得了发展,我们已经积累了不少针对各种任务的不同管理接口。我们通常为新的展示需求创建新模块,比如我们自己的博客、图表等。我们还定期开发内部工具来处理诸如部署、可视化操作及事件处理等事务。在处理这些事务中,我们使用了几个不同的接口来认证:
&n
- 利用tomcat-redis-session-manager做session同步时自定义类对象属性保存不上的解决方法
bsr1983
session
在利用tomcat-redis-session-manager做session同步时,遇到了在session保存一个自定义对象时,修改该对象中的某个属性,session未进行序列化,属性没有被存储到redis中。 在 tomcat-redis-session-manager的github上有如下说明: Session Change Tracking
As noted in the &qu
- 《代码大全》表驱动法-Table Driven Approach-1
bylijinnan
java算法
关于Table Driven Approach的一篇非常好的文章:
http://www.codeproject.com/Articles/42732/Table-driven-Approach
package com.ljn.base;
import java.util.Random;
public class TableDriven {
public
- Sybase封锁原理
chicony
Sybase
昨天在操作Sybase IQ12.7时意外操作造成了数据库表锁定,不能删除被锁定表数据也不能往其中写入数据。由于着急往该表抽入数据,因此立马着手解决该表的解锁问题。 无奈此前没有接触过Sybase IQ12.7这套数据库产品,加之当时已属于下班时间无法求助于支持人员支持,因此只有借助搜索引擎强大的
- java异常处理机制
CrazyMizzz
java
java异常关键字有以下几个,分别为 try catch final throw throws
他们的定义分别为
try: Opening exception-handling statement.
catch: Captures the exception.
finally: Runs its code before terminating
- hive 数据插入DML语法汇总
daizj
hiveDML数据插入
Hive的数据插入DML语法汇总1、Loading files into tables语法:1) LOAD DATA [LOCAL] INPATH 'filepath' [OVERWRITE] INTO TABLE tablename [PARTITION (partcol1=val1, partcol2=val2 ...)]解释:1)、上面命令执行环境为hive客户端环境下: hive>l
- 工厂设计模式
dcj3sjt126com
设计模式
使用设计模式是促进最佳实践和良好设计的好办法。设计模式可以提供针对常见的编程问题的灵活的解决方案。 工厂模式
工厂模式(Factory)允许你在代码执行时实例化对象。它之所以被称为工厂模式是因为它负责“生产”对象。工厂方法的参数是你要生成的对象对应的类名称。
Example #1 调用工厂方法(带参数)
<?phpclass Example{
- mysql字符串查找函数
dcj3sjt126com
mysql
FIND_IN_SET(str,strlist)
假如字符串str 在由N 子链组成的字符串列表strlist 中,则返回值的范围在1到 N 之间。一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串。如果第一个参数是一个常数字符串,而第二个是type SET列,则 FIND_IN_SET() 函数被优化,使用比特计算。如果str不在strlist 或st
- jvm内存管理
easterfly
jvm
一、JVM堆内存的划分
分为年轻代和年老代。年轻代又分为三部分:一个eden,两个survivor。
工作过程是这样的:e区空间满了后,执行minor gc,存活下来的对象放入s0, 对s0仍会进行minor gc,存活下来的的对象放入s1中,对s1同样执行minor gc,依旧存活的对象就放入年老代中;
年老代满了之后会执行major gc,这个是stop the word模式,执行
- CentOS-6.3安装配置JDK-8
gengzg
centos
JAVA_HOME=/usr/java/jdk1.8.0_45
JRE_HOME=/usr/java/jdk1.8.0_45/jre
PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin
CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib
export JAVA_HOME
- 【转】关于web路径的获取方法
huangyc1210
Web路径
假定你的web application 名称为news,你在浏览器中输入请求路径: http://localhost:8080/news/main/list.jsp 则执行下面向行代码后打印出如下结果: 1、 System.out.println(request.getContextPath()); //可返回站点的根路径。也就是项
- php里获取第一个中文首字母并排序
远去的渡口
数据结构PHP
很久没来更新博客了,还是觉得工作需要多总结的好。今天来更新一个自己认为比较有成就的问题吧。 最近在做储值结算,需求里结算首页需要按门店的首字母A-Z排序。我的数据结构原本是这样的:
Array
(
[0] => Array
(
[sid] => 2885842
[recetcstoredpay] =&g
- java内部类
hm4123660
java内部类匿名内部类成员内部类方法内部类
在Java中,可以将一个类定义在另一个类里面或者一个方法里面,这样的类称为内部类。内部类仍然是一个独立的类,在编译之后内部类会被编译成独立的.class文件,但是前面冠以外部类的类名和$符号。内部类可以间接解决多继承问题,可以使用内部类继承一个类,外部类继承一个类,实现多继承。
&nb
- Caused by: java.lang.IncompatibleClassChangeError: class org.hibernate.cfg.Exten
zhb8015
maven pom.xml关于hibernate的配置和异常信息如下,查了好多资料,问题还是没有解决。只知道是包冲突,就是不知道是哪个包....遇到这个问题的分享下是怎么解决的。。
maven pom:
<dependency>
<groupId>org.hibernate</groupId>
<ar
- Spark 性能相关参数配置详解-任务调度篇
Stark_Summer
sparkcachecpu任务调度yarn
随着Spark的逐渐成熟完善, 越来越多的可配置参数被添加到Spark中来, 本文试图通过阐述这其中部分参数的工作原理和配置思路, 和大家一起探讨一下如何根据实际场合对Spark进行配置优化。
由于篇幅较长,所以在这里分篇组织,如果要看最新完整的网页版内容,可以戳这里:http://spark-config.readthedocs.org/,主要是便
- css3滤镜
wangkeheng
htmlcss
经常看到一些网站的底部有一些灰色的图标,鼠标移入的时候会变亮,开始以为是js操作src或者bg呢,搜索了一下,发现了一个更好的方法:通过css3的滤镜方法。
html代码:
<a href='' class='icon'><img src='utv.jpg' /></a>
css代码:
.icon{-webkit-filter: graysc