联想a788t线刷包的mock location在哪

java - Android Error testing app using Mock Location - Stack Overflow
to customize your list.
Announcing Stack Overflow Documentation
We started with Q&A. Technical documentation is next, and we need your help.
Whether you're a beginner or an experienced developer, you can contribute.
I'm trying to test my Android location based app.
It would be very useful if I could mock location data from providers in unit tests. But I can't add ACCESS_MOCK_LOCATION permission to androidManifest.xml because when I do so it gives me an error:
Mock locations should only be requested in a debug-specific manifest file (typically src/debug/AndroidManifest.xml)
Using a mock location provider (by requiring the permission
android.permission.ACCESS_MOCK_LOCATION) should only be done in debug
builds. In Gradle projects, that means you should only request this
permission in a debug source set specific manifest file.
To fix this,
create a new manifest file in the debug folder and move the
element there. A typical path to a debug manifest
override file in a Gradle project is src/debug/AndroidManifest.xml.
But I when add AndroidManifest.xml to src/androidTest directory - it just ignores it when testing.
What am I doing wrong?
I just had this problem and I think I figured out the solution.
Make sure that "Access mock locations" is checked in your device Developer Options (in addition to making an "src/debug/AndroidManifest.xml" file declaring usage of the ACCESS_MOCK_LOCATION permission, as you are already doing).
But I when add AndroidManifest.xml to src/androidTest directory - it just ignores it when testing.
Have you tried putting it in the src/debug folder according to the error message? That should work just fine.
Your Answer
Sign up or
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Post as a guest
By posting your answer, you agree to the
Not the answer you're looking for?
Browse other questions tagged
Stack Overflow works best with JavaScript enabled加入应用集
云安装到手机
<button type="button" class="btn btn-default ex-btn-glyphicon hidden-xs" data-toggle="popover" data-placement="bottom" data-trigger="hover" data-container="body" data-html="true" title="扫描二维码下载到手机" data-content="">二维码
Fake GPS Location这类型的软件不少,不过界面做的好的真心没几个,这个应该是小编见过最好的了,可以把洋妞了。 点评来自 @酷安小编
我的评分(未评分)
软件名称:伪装位置:Fake GPS Location
APK名称:com.fakegps.mock
最新版本:3.470
支持ROM:2.3及更高版本
界面语言:简体中文
软件大小:3.65 M
更新日期:
开发者:Andev
android.permission.ACCESS_NETWORK_STATE获取网络状态 获取网络信息状态,如当前的网络连接是否有效
android.permission.INTERNET访问网络 访问网络连接,可能产生GPRS流量
android.permission.WRITE_EXTERNAL_STORAGE写入外部存储 允许程序写入外部存储,如SD卡上写文件
android.permission.ACCESS_COARSE_LOCATION获取粗略位置 通过WiFi或移动基站的方式获取用户粗略的经纬度信息,定位精度大概误差在30~1500米
android.permission.ACCESS_FINE_LOCATION获取精确位置 通过GPS芯片接收卫星的定位信息,定位精度达10米以内
android.permission.ACCESS_MOCK_LOCATION获取模拟定位信息 获取模拟定位信息
android.permission.ACCESS_WIFI_STATE获取WiFi状态 获取当前WiFi接入的状态以及WLAN热点的信息
com.fakegps.mock.permission.MAPS_RECEIVE
com.google.android.providers.gsf.permission.READ_GSERVICES
com.android.vending.BILLING
加入应用集
Fake GPS Location是一款可以模拟手机GPS位置的应用,需要将手机的模拟方位打开。
分类标签:
Added remove ads option.
更新版本:3.470
更新版本:3.460
更新版本:3.458
更新版本:3.457
更新版本:3.456
我们公司搞了个深信服的app签到软件,尝试了数个虚拟地址,伪造地址的工具如xprivacy,fake gps,任意行等全部阵亡,现在百度地图8.1版本也不能伪造地址了,全部通过基站取得了真实的地址,何解?
系统:4.4.2...
6.3.22微信……
我能说是为了ingress吗#(滑稽)
有没有不root修改GPS的
定位失败怎么办?
这货会有什么样的使用场景呢,我陷入了深思。当我不想让别人知道我在哪儿的我一般是怎么做的,想了一下,我好像是直接把应用的定位权限拒绝掉。好吧,这个场景不行,那么我想让别人以为我到了一个我从没去过的地方。我会怎么做呢,看了一眼手机,以前的饥渴版360杀毒貌似就可以了。然后我再想这货的使用场景,没错,我已经想不出了!!!
fake黄色版,
直接用钛备份把软件转为系统程序就可以了,要打开gps才能完美模拟
现在安装这个的,大部分都是为了pokemon go#(滑稽)#(滑稽)#(滑稽)#(滑稽)
求坐标,哪里的鲤鱼王超多,告诉下坐标。
检测位置失败
用此工具只为了pokemon go
我写了个xposed模块,可以伪装运营商,基站信息,gps,wifi,成功伪装成米国。你们要么,不过有广告。以前没学过java,Android,一点点写的加点广告不过分吧?百度全家测试可用,谷歌全家测试可用。
一直在真实地点和虚拟地点之间跳动…不知何故#(泪)
pokemon go+1
微信附近的人是变了!但是添加没有一个回复同意的!岂不是自慰的嘛
微信6.3.5伪装失败
不知道怎么用?地图都显示不出来
吊大的可以告诉我地图为什么显示不出来及方法吗
Ingress升到3级,然后hack完全失灵,脚也插不下去
谁知道,“陌陌”哪个旧版本支持打开“模拟位置”定位?????
这玩意用不懂
开了这货玩ingress 现在半ban状态了
微信使用方法,允许模拟位置,启动伪装位置,打开gps,用lbe大师将微信的定位权限改为提示,微信中请求定位的时候第一次是来自小区基站,选择拒绝,第二次是来自gps,选择允许。
微信6.3.5无效
没用Google框架可以用吗?
这个需要Google play吗
狂刷版本号…
這跟那個UI及圖標萬年不變的醜八怪哪個好使?
1.更小的安装包
希望口袋妖怪go能用到
这货最近怎么老是升级
为啥我用了还是失效了
这个软件内置的地图是谷歌map,如何使用高德或者百度呢!
居然有中文?
我想定位到火星成不?
可以用这个开启Google的 location histroy嘛,不root的情况下。。。。
这货更新了啥…新版本FC
好应用,就是手机的RAM小…经常用满了……
装了也用不了Google 即时
酷安的程序员在哪?你们的软件,经常要点好几下才能进去!我去任何网站都没有这种问题
这个伪装位置可以在哪些应用中起到作用?
现在最新版的百度地图和微信 QQ都已经没法用了吧
这类软件我几乎用不到
老是闪退…
马克一下子
form>div>textarea" data-dock="left"
data-placement="top">
form').submit();">回复1223人阅读
android(12)
转载文章请注明出处:http://blog.csdn.net/dangxw_/article/details/
现在软件市场上有很多可以改变手机地理位置的软件,更改后打开微信就可以随意定位,甚至前几年有依靠这个技术打广告为生的小型公司。
一获取地理位置的方法
获取地理位置的方法一般分为两种。
24颗卫星定位全球(图片来自维基百科)给出详解地址:http://zh.wikipedia.org/wiki/GPS;
但是向卫星对请求信号强度的要求比较高,很多专门的硬件设备有时都达不到,所以手机使用GPS这种方法百分之九十的可能获取的是null。
2)network
这种方法其实又分为两种情况。一种是有线一种为无线。
因为是有线的网络位置固定,每个接入点的ip为又是固定的,网络的ip和位置就产生一一对应关系。根据接入点的ip既可得到地理位置。不过这些工作&#20284;乎是系统或者网络提供商要做的,不用android的开发者解析。
无线使用的是基站定位。实际上也就是数学上的三点定位。例如移动公司,其基站遍布全国,如果一台设备想要连无线网,附近的三个基站会根据信号强度判断出访问者的相对距离,画出三个半径为距离的园,根据三个圆的交点得知大致地理坐标。(图片来着百度百科)
例如某些平板电脑,不能插入网卡,不能插入手机卡,它们访问网络就都是走的wifi,那么它的地理位置获取就是根据wifi共享设备的地理位置来大致确定的。wifi共享设备的地理位置的确定参看以上1,2;
二:获取地理位置
android 提供了
locationmanager 类来管理地理位置信息,其中提供了添加,删除,筛选等很方便的功能。
android.location.LocationManager
这个对象不能new ,只能从系统获取
Class Overview
This class provides access to the system location services. These services allow applications to obtain periodic updates of the device's geographical location, or to fire an application-specified&when
the device enters the proximity of a given geographical location.
You do not instantiate instead, retrieve it through&.
Unless noted, all Location API methods require the&&or&&permissions.
If your application only has the coarse permission then it will not have access to the GPS or passive location providers. Other providers will still return location results, but the update rate will be throttled and the exact location will be obfuscated to
a coarse level of accuracy.
另外,这个对象获取所有的位置提供者,并且进行删除,添加,等操作。
太多了,不复制,直接给出api链接好了:/reference/android/location/LocationManager.html
在了解这个类之后再获取当前的地理位置就简单多了。网上有很多代码。
大致是获取位置提供者,循环像每个提供者索要地理信息,信息被系统包装成了Location这个类。
获取Location对象后可以调用
public Location getLocation(Context context) {
LocationManager locMan = (LocationManager) context
.getSystemService(Context.LOCATION_SERVICE);
Location location = locMan
.getLastKnownLocation(LocationManager.GPS_PROVIDER);
if (location == null) {
location = locMan
.getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
为什么要获取两次,因为刚才所说,一般获取GPS获取不到,不过其实获取两次应该也是null。
对于getLastKownLocation()
(&provider)
Returns a Location indicating the data from the last known location fix obtained from the given provider.
他接受一个提供者名字的参数,一般如果调用系统的话有:
GPS_PROVIDER, NETWORK_PROVIDER, 这两个容易理解,一个是网络一个是gps 另外,还有一个PASSIVE_PROVIDER&
public static final&&PASSIVE_PROVIDER
这个究竟是什么暂时还没搞懂。
不过你也可以手动获取所有提供者,因为有可能本机的设备已经添加了某些位置提供者(下一部分分析添加位置给系统,即 虚拟地理位置),我想大多数软件都是这么写的或者说应该这么写,获取所有位置提供者,然后循环索要location:
enabledOnly)
Returns a list of the names of location providers.
(&criteria,
boolean enabledOnly)
Returns a list of the names of LocationProviders that satisfy the given criteria, or null if none do.
用到这两个方法,对于第二个重载的方法的第一个参数,意思是限制条件类,即根据所提供的对位置提供者的限制返回符合要求的名称。
获取String数组后就可以循环获取位置:
private Location getLocation()
for(int i = 0; i & locProvider.length, i ++)
Location location = locationManager.getLocation(locProvider.get(i));
if(location!=null)
另外,也可以对现有的位置提供者进行修改(系统原有的三个修改不了),不过需要
1,获取LocationProvider 类&
Returns the information associated with the location provider of the given name, or null if no provider exists by that name.
/reference/android/location/LocationProvider.html
3删除原有的
(&provider)
Removes the mock location provider with the given name.
4添加修改后的。
boolean requiresNetwork, boolean requiresSatellite, boolean requiresCell, boolean hasMonetaryCost, boolean supportsAltitude, boolean supportsSpeed, boolean supportsBearing, int powerRequirement, int accuracy)
Creates a mock location provider and adds it to the set of active providers.
当然要加入相应的权限:
&uses-permission android:name=&android.permission.ACCESS_FINE_LOCATION&/&
三 虚拟地理位置
其实google play 上就有现成的程序:/store/apps/details?id=com.lexa.fakegps&hl=zh_TW,
而且github上有托管的源代码.
具体方法是添加位置提供者,不断向位置提供者传递locaiton信息。
public void&setTestProviderEnabled&(&provider,
boolean enabled)
这个也是需要加入特殊权限的:
&uses-permission android:name=&android.permission.ACCESS_MOCK_LOCATION&/&
另外,经过测试发现,不如直接给“gps”传位置,其他软件更容易接受,不过需要使用者把虚拟地理位置选项打开。
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:23462次
排名:千里之外
原创:28篇
评论:29条加入应用集
云安装到手机
<button type="button" class="btn btn-default ex-btn-glyphicon hidden-xs" data-toggle="popover" data-placement="bottom" data-trigger="hover" data-container="body" data-html="true" title="扫描二维码下载到手机" data-content="">二维码
浮动位置伪装和同类应用相比最大的特点在于浮动窗口,减去了切换窗口的操作,应用本身需要开发者设置的伪装地理位置选项。 点评来自 @zesty
我的评分(未评分)
软件名称:浮动位置伪装:Floater Fake Location
APK名称:com.marlon.floating.fake.location
最新版本:1.28
支持ROM:4.0.3及更高版本
界面语言:英文软件
软件大小:2.08M
更新日期:1天前
开发者:Rapid Developers
android.permission.SYSTEM_ALERT_WINDOW显示系统窗口 显示系统窗口
android.permission.INTERNET访问网络 访问网络连接,可能产生GPRS流量
android.permission.ACCESS_NETWORK_STATE获取网络状态 获取网络信息状态,如当前的网络连接是否有效
android.permission.ACCESS_COARSE_LOCATION获取粗略位置 通过WiFi或移动基站的方式获取用户粗略的经纬度信息,定位精度大概误差在30~1500米
android.permission.WRITE_EXTERNAL_STORAGE写入外部存储 允许程序写入外部存储,如SD卡上写文件
android.permission.ACCESS_FINE_LOCATION获取精确位置 通过GPS芯片接收卫星的定位信息,定位精度达10米以内
android.permission.ACCESS_MOCK_LOCATION获取模拟定位信息 获取模拟定位信息
android.permission.WRITE_SETTINGS读写系统设置 允许读写系统设置项
android.permission.WRITE_SECURE_SETTINGS读写系统敏感设置 允许程序读写系统安全敏感的设置项
android.permission.INSTALL_LOCATION_PROVIDER安装定位服务 安装定位提供
android.permission.ACCESS_LOCATION_EXTRA_COMMANDS访问额外定位命令 允许程序访问额外的定位提供者指令,一般用于帮助开发者调试应用
android.permission.RECEIVE_BOOT_COMPLETED开机自动允许 允许程序开机自动运行
com.marlon.floating.fake.location.permission.MAPS_RECEIVE
com.google.android.providers.gsf.permission.READ_GSERVICES
com.android.vending.BILLING
加入应用集
浮动位置伪装应用是一款伪装所在位置的应用,并且以浮动窗口的格式运行,让你更加方便的使用其它应用。伪装你的手机至世界上的任何位置。这个应用可以设置你的GPS伪装位置,因此其它应用会认为你处于那里。
分类标签:
Before commenting on Play Store please read the FAQs:
Floater Settings -> About -> FAQs
- Url entry of custom Json variables
- Updated default values
- Added GPS to name
- Stability fixes
- Errors on favorites
终于弄好了,全部可以用
本来有xx助手的,太落后,删了。
防止带坏小朋友还是打码比较好。
浮动搞好了可以移动了
问题是地图上只有草原 补给点精灵什么都没有[dw哭]怎么办
每次更新都自动装到SD卡里是几个意思,我要破解广告啊喂
恕瑞玛,你的皇帝飞升了!
图标好像千年锡杖#(乖)
最新版本为什么一直白屏显示更新
一看图标我还以为Skt发布了一个战队粉丝app呢:joy:
用这个可以得王者荣耀安琪拉必胜客皮肤了吗
为什么我开了模拟位置,软件还是提醒我需要模拟位置权限,有没有相同的小伙伴?还有就是先开始用floater配合hide可以是用,后面用了pokemon go controls然后又用floater(由于controls不能输坐标)就开始提醒没有打开位置模拟了(什么设置都没用动过,和原来能用的时候是一样的。),但是conreols不管什么时候都能用:joy:
这个图标,SKT好吧#(真棒)
是有多少人拿這個去用微信,還給一星差評,導致作者新版要特別跳提醒說不支持,還把微信放在第一順位,超越Pokémon和ingress #(滑稽)
求救,回不去了,mock,floater已经删除,模拟位置已经关掉,但是地图定位还是这样
图标联想到飞嘀打车
就我一个想到闪电侠吗#(滑稽)
软件阵亡了?新版旧版都不管用了
还要google play。老外的应用真是
恕我直言,更新后不开定位还将就,TMD一打开定位那尼玛卡得麻麻都不认识咯[doge笑哭]
更新后十分卡
表示hide moke location越更新越差,最新版本定位到旧金山了,然后过了一会就gps信号不好,重登一道游戏就回到国内了,然后我就被封号了,还是1.1版本最好用。
飘扬海外的国内飞机党玩家传来消息,7月30日晚间,旧金山已被锁区。
目前,旧金山全区已无补给站踪影,飞机党老巢联合广场、渔人码头等地区空空如也。
突然遭此噩耗,美国玩家表示愤怒,同时,数十万国内飞机党玩家正准备撤离旧金山地区。
任天堂为何突然锁区旧金山,目前不得而知,请时刻关注最新消息。
这个方法百分比可玩。
非6.0可以试一下楼下说的用幸运破解安装到system
Floater fake location 安装后需要配置的么?打开之后。运行pokemon go 人物无法移动
闪退怎么回事
可以玩pokemon go 但移动一次要重新获取一次GPS信号
首先层主是魅族note2 5.1安卓
按照评论所说的得出以下结论
用幸运破解安装到system
这app就失去伪装定位的功能
如果普通安装,就需要打开虚拟位置
然而pmgo就没办法玩了
最后你安装mml(伪装伪装位置,英文我忘记了)一样不行
你开启虚拟位置,这app认不出
然后就是这样死循环。。。。。。。
6.0闪退怎么办…
这个怎么玩[喵喵笑哭]
一直在停止运行[喵喵笑哭]
不能移动位置怎么破,空白一片
录取路线,孵蛋专用。。。后台挂着,就是不稳定,有时候飞回去真实地址
更新的什么啊
6.0.1亲测可用
什么vpn好用
玩Pokémon GO老是和真实位置来回切换咋回事
怎么录取线路啊,求教程
虚拟位置(Fake GPS)是严重的作弊行为,请各位训练师遵守游戏规则,耐心等待大陆地区开服,维护健康的游戏环境。对于讨论与使用作弊的玩家,我们将一律向Niantic举报。
安卓5.1.1怎么允许模拟位置,魅族flyme5
为什么我刷机后,重新安装,空白一片不显示地图了
为什么两个隐藏模拟位置的都对这应用隐藏了,设置了白名单都没有用,求大大帮帮忙?
这个怎么调节移动速度啊
求美国旧金山联合广场坐标,经纬度
已被封号 捕捉百分百逃跑 不能获得补给
不开模拟位置用不了,开了模拟位置go就没精灵
。。。。。。我去
定位挂了,现在把我定位到美国了,我都删了应用,关了模拟
状态栏提示no location set,闪退,开了模拟位置,没装伪装的xp插件,日
求坐标,哪里的鲤鱼王超多,告诉下坐标。
定位fail的 终极解决办法已经出来了 清直接在框架里更新mock mock
form>div>textarea" data-dock="left"
data-placement="top">
form').submit();">回复2658人阅读
J2EE(14)
Spring(5)
Spring(5)
一、前言:
二、核心类与接口:
三、核心流程图
四、DispatcherServlet说明
五、双亲上下文的说明
六、springMVC-mvc.xml 配置文件片段讲解&
七、如何访问到静态的文件,如jpg,js,css?
八、请求如何映射到具体的Action中的方法?
九、Spring中的拦截器:
十、如何使用拦截器?
十一、如何实现全局的异常处理?
十二、如何把全局异常记录到日志中?
十三、如何给spring3 MVC中的Action做JUnit单元测试?&&
十四、转发与重定向&
十五、处理ajax请求
十六、关于写几个配置文件的说明&
十七、如何取得Spring管理的bean
十八、多视图控制器
十九、 &mvc:annotation-driven /& 到底做了什么工作&
二十、 本文中springMVC.xml配置文件是核心,这里给一个下载地址
一、前言:
大家好,Spring3 MVC是非常优秀的MVC框架,由其是在3.0版本发布后,现在有越来越多的团队选择了Spring3 MVC了。Spring3 MVC结构简单,应了那句话简单就是美,而且他强大不失灵活,性能也很优秀。
官方的下载网址是:&& (本文使用是的Spring 3.0.5版本)
Struts2也是比较优秀的MVC构架,优点非常多比如良好的结构。但这里想说的是缺点,Struts2由于采用了&#20540;栈、OGNL表达式、struts2标签库等,会导致应用的性能下降。Struts2的多层拦截器、多实例action性能都很好。可以参考我写的一篇关于Spring MVC与Struts2与Servlet比较的文章&
Spring3 MVC的优点:
1、Spring3 MVC的学习难度小于Struts2,Struts2用不上的多余功能太多。呵呵,当然这不是决定因素。
2、Spring3 MVC很容易就可以写出性能优秀的程序,Struts2要处处小心才可以写出性能优秀的程序(指MVC部分)
3、Spring3 MVC的灵活是你无法想像的,Spring的扩展性有口皆碑,Spring3 MVC当然也不会落后,不会因使用了MVC框架而感到有任何的限制。
Struts2的众多优点:略...&& (呵呵,是不是不公平?)
众多文章开篇时总要吹些牛,吸引一下读者的&#30524;球,把读者的胃口调起来,这样大家才有兴趣接着往后看。本文也没能例外。不过保证你看了之后不会后悔定有收获。
转载请注明出处:本文地址:
二、核心类与接口:
先来了解一下,几个重要的接口与类。现在不知道他们是干什么的没关系,先混个脸熟,为以后认识他们打个基础。
DispatcherServlet&& -- 前置控制器
HandlerMapping接口 -- 处理请求的映射
HandlerMapping接口的实现类:
SimpleUrlHandlerMapping& 通过配置文件,把一个URL映射到Controller
DefaultAnnotationHandlerMapping& 通过注解,把一个URL映射到Controller类上
HandlerAdapter接口 -- 处理请求的映射
AnnotationMethodHandlerAdapter类,通过注解,把一个URL映射到Controller类的方法上
Controller接口 -- 控制器
由于我们使用了@Controller注解,添加了@Controller注解注解的类就可以担任控制器(Action)的职责,
所以我们并没有用到这个接口。
HandlerInterceptor 接口--拦截器
无图,我们自己实现这个接口,来完成拦截的器的工作。
ViewResolver接口的实现类
UrlBasedViewResolver类 通过配置文件,把一个视图名交给到一个View来处理
InternalResourceViewResolver类,比上面的类,加入了JSTL的支持
JstlView类
LocalResolver接口
HandlerExceptionResolver接口 --异常处理
SimpleMappingExceptionResolver实现类
ModelAndView类
三、核心流程图
本图是我个人画的,有不严谨的地方,大家对付看吧。总比没的看强。
转载请注明出处:本文地址:
四、DispatcherServlet说明
使用Spring MVC,配置DispatcherServlet是第一步。
DispatcherServlet是一个Servlet,所以可以配置多个DispatcherServlet。
DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自已定义,把拦截下来的请求,依据某某规则分发到目标Controller(我们写的Action)来处理。
“某某规则”:是根据你使用了哪个HandlerMapping接口的实现类的不同而不同。
先来看第一个例子:
&&&&&&&&example&&
&&&&&&&&org.springframework.web.servlet.DispatcherServlet&&
&&&&&&&&1&&
&&&&&&&&example&&
&&&&&&&&*.form&&
&&load-on-startup&1&/load-on-startup&是启动顺序,让这个Servlet随Servletp容器一起启动。
&&url-pattern&*.form&/url-pattern& 会拦截*.form结尾的请求。
&&servlet-name&example&/servlet-name&这个Servlet的名字是example,可以有多个DispatcherServlet,是通过名字来区分的。每一个DispatcherServlet有自己的WebApplicationContext上下文对象。同时保存的ServletContext中和Request对象中,关于key,以后说明。
在DispatcherServlet的初始化过程中,框架会在web应用的 WEB-INF文件夹下寻找名为[servlet-name]-servlet.xml 的配置文件,生成文件中定义的bean。
第二个例子:
&&&&springMVC&&
&&&&org.springframework.web.servlet.DispatcherServlet&&
&&&&&&&&contextConfigLocation&&
&&&&&&&&classpath*:/springMVC.xml&&
&&&&springMVC&&
指明了配置文件的文件名,不使用默认配置文件名,而使用springMVC.xml配置文件。
其中&param-value&**.xml&/param-value& 这里可以使用多种写法
1、不写,使用默认&#20540;:/WEB-INF/&servlet-name&-servlet.xml
2、&param-value&/WEB-INF/classes/springMVC.xml&/param-value&
3、&param-value&classpath*:springMVC-mvc.xml&/param-value&
4、多个&#20540;用逗号分隔
Servlet拦截匹配规则可以自已定义,Servlet拦截哪种URL合适?&
当映射为@RequestMapping(&/user/add&)时:
1、拦截*.do,例如:/user/add.do,弊端:所有的url都要以.do结尾。不会影响访问静态文件。
2、拦截/app/*,例如:/app/user/add,弊端:请求的url都要包含/app,@RequestMapping(&/user/add&)中不须要包含/app。
3、拦截/,例如:/user/add,弊端:对jpg,js,css静态文件的访问也被拦截不能正常显示。后面有解决办法。
4、拦截/*,可以走到Action中,但转发到jsp时再次被拦截,不能访问到jsp。
五、双亲上下文的说明
如果你使用了listener监听器来加载配置,一般在Struts&#43;Spring&#43;Hibernate的项目中都是使用listener监听器的。如下
Java代码&&
&listener&&&&
&&&listener-class&org.springframework.web.context.ContextLoaderListener&/listener-class&&&&
&/listener&&&&
Spring会创建一个全局的WebApplicationContext上下文,称为根上下文&,保存在&ServletContext中,key是WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE属性的&#20540;。可以使用工具类取出上下文:WebApplicationContextUtils.getWebApplicationContext(ServletContext);
DispatcherServlet是一个Servlet,可以同时配置多个,每个&DispatcherServlet有一个自己的&WebApplicationContext上下文,这个上下文继承了&根上下文&中所有东西。&保存在&ServletContext中,key是&org.springframework.web.servlet.FrameworkServlet.CONTEXT&&#43;Servlet名称。当一个Request对象产生时,会把这个WebApplicationContext上下文保存在Request对象中,key是DispatcherServlet.class.getName()
&#43; &.CONTEXT&。可以使用工具类取出上下文:RequestContextUtils.getWebApplicationContext(request);
Spring中的 ApplicationContext实例可以被限制在不同的作用域(scope)中。
在web MVC框架中,每个 DispatcherServlet有它自己的WebApplicationContext ,这个context继承了根 WebApplicationContext 的所有bean定义。
这些继承的bean也可以在每个serlvet自己的所属的域中被覆盖(override),覆盖后的bean 可以被设置上只有这个servlet实例自己使用的属性。
总结:不使用listener监听器来加载spring的配置,改用DispatcherServlet来加载spring的配置,不要双亲上下文,只使用一个DispatcherServlet,事情就简单了,什么麻烦事儿也没有了。
六、springMVC-mvc.xml 配置文件片段讲解&(未使用默认配置文件名)
&version=&1.0&&encoding=&UTF-8&&&
&&&&xmlns=&http://www.springframework.org/schema/beans&&&
&&&&xmlns:xsi=&http://www.w3.org/2001/XMLSchema-instance&&&
&&&&xmlns:tx=&http://www.springframework.org/schema/tx&&&
&&&&xmlns:context=&http://www.springframework.org/schema/context&&&&&
&&&&xmlns:mvc=&http://www.springframework.org/schema/mvc&&&&&
&&&&xsi:schemaLocation=&http://www.springframework.org/schema/beans&&&
&&&&http://www.springframework.org/schema/beans/spring-beans-3.0.xsd&&&
&&&&http://www.springframework.org/schema/tx&&&
&&&&http://www.springframework.org/schema/tx/spring-tx-3.0.xsd&&
&&&&http://www.springframework.org/schema/context&&
&&&&http://www.springframework.org/schema/context/spring-context-3.0.xsd&&
&&&&http://www.springframework.org/schema/mvc&&
&&&&http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd&&&
&&&&&base-package=&com.app,com.core,JUnit4&&&&
&&&&&class=&org.springframework.web.servlet.view.InternalResourceViewResolver&&&
&&&&&&&&&name=&prefix&&value=&/WEB-INF/jsp/&&&
&&&&&&&&&name=&suffix&&value=&.jsp&&&
&&&&&&&&&name=&viewClass&&value=&org.springframework.web.servlet.view.JstlView&&&&
&&&&&&&&&class=&com.core.mvc.MyInteceptor&&&&
&&&&&&&&&&&
&&&&&mapping=&/images/**&&location=&/images/&&cache-period=&&&&
&&&&&mapping=&/js/**&&location=&/js/&&cache-period=&&&&
&&&&&mapping=&/css/**&&location=&/css/&&cache-period=&&&&
&context:component-scan/& 扫描指定的包中的类上的注解,常用的注解有:
@Controller 声明Action组件
@Service&&& 声明Service组件&&& @Service(&myMovieLister&)&
@Repository 声明Dao组件
@Component&& 泛指组件, 当不好归类时.&
@RequestMapping(&/menu&)& 请求映射
@Resource& 用于注入,( j2ee提供的 ) 默认按名称装配,@Resource(name=&beanName&)&
@Autowired 用于注入,(srping提供的) 默认按类型装配&
@Transactional( rollbackFor={Exception.class}) 事务管理
@ResponseBody
@Scope(&prototype&)&& 设定bean的作用域
&mvc:annotation-driven /& 是一种简写形式,完全可以手动配置替代这种简写形式,简写形式可以让初学都快速应用默认配置方案。&mvc:annotation-driven /& 会自动注册DefaultAnnotationHandlerMapping与AnnotationMethodHandlerAdapter 两个bean,是spring MVC为@Controllers分发请求所必须的。
并提供了:数据绑定支持,@NumberFormatannotation支持,@DateTimeFormat支持,@Valid支持,读写XML的支持(JAXB),读写JSON的支持(Jackson)。
后面,我们处理响应ajax请求时,就使用到了对json的支持。
后面,对action写JUnit单元测试时,要从spring IOC容器中取DefaultAnnotationHandlerMapping与AnnotationMethodHandlerAdapter 两个bean,来完成测试,取的时候要知道是&mvc:annotation-driven /&这一句注册的这两个bean。
如何替换&&mvc:annotation-driven /&?他到底做了什么工作,请看,最后面的 十九节&&mvc:annotation-driven /&&到底做了什么工作。
&mvc:interceptors/& 是一种简写形式。通过看前面的大图,知道,我们可以配置多个HandlerMapping。&mvc:interceptors/&会为每一个HandlerMapping,注入一个拦截器。其实我们也可以手动配置为每个HandlerMapping注入一个拦截器。
&mvc:default-servlet-handler/& 使用默认的Servlet来响应静态文件。
&mvc:resources mapping=&/images/**& location=&/images/& cache-period=&&/& 匹配URL& /images/**& 的URL被当做静态资源,由Spring读出到内存中再响应http。
转载请注明出处:本文地址:
七、如何访问到静态的文件,如jpg,js,css?
如何你的DispatcherServlet拦截 *.do这样的URL,就不存在访问不到静态资源的问题。如果你的DispatcherServlet拦截“/”,拦截了所有的请求,同时对*.js,*.jpg的访问也就被拦截了。
目的:可以正常访问静态文件,不要找不到静态文件报404。
方案一:激活Tomcat的defaultServlet来处理静态文件
&&&&default&&
&&&&*.jpg&&&&&
&&&&default&&&&
&&&&*.js&&&&
&&&&default&&&&&&&
&&&&*.css&&&&&&
要配置多个,每种文件配置一个&&&
要写在DispatcherServlet的前面, 让&defaultServlet先拦截,这个就不会进入Spring了,我想性能是最好的吧。
Tomcat, Jetty, JBoss, and GlassFish 自带的默认Servlet的名字 -- &default&
Google App Engine&自带的&默认Servlet的名字 -- &_ah_default&
Resin&自带的&默认Servlet的名字 -- &resin-file&
WebLogic&自带的&默认Servlet的名字& -- &FileServlet&
WebSphere&&自带的&默认Servlet的名字 -- &SimpleFileServlet&&
方案二: 在spring3.0.4以后版本提供了mvc:resources&
mvc:resources 的使用方法:
&mapping=&/images/**&&location=&/images/&&&&
/images/**映射到ResourceHttpRequestHandler进行处理,location指定静态资源的位置.可以是web application根目录下、jar包里面,这样可以把静态资源压缩到jar包中。cache-period 可以使得静态资源进行web cache&
如果出现下面的错误,可能是没有配置&mvc:annotation-driven /&的原因。&
报错WARNING: No mapping found for HTTP request with URI [/mvc/user/findUser/lisi/770] in DispatcherServlet with name 'springMVC'
使用&mvc:resources/&元素,把mapping的URI注册到SimpleUrlHandlerMapping的urlMap中,
key为mapping的URI pattern&#20540;,而value为ResourceHttpRequestHandler,
这样就巧妙的把对静态资源的访问由HandlerMapping转到ResourceHttpRequestHandler处理并返回,所以就支持classpath目录,jar包内静态资源的访问.
另外需要注意的一点是,不要对SimpleUrlHandlerMapping设置defaultHandler.因为对static uri的defaultHandler就是ResourceHttpRequestHandler,
否则无法处理static resources request.
方案三 ,使用&mvc:default-servlet-handler/&
会把&/**& url,注册到SimpleUrlHandlerMapping的urlMap中,把对静态资源的访问由HandlerMapping转到org.springframework.web.servlet.resource.DefaultServletHttpRequestHandler处理并返回.
DefaultServletHttpRequestHandler使用就是各个Servlet容器自己的默认Servlet.
补充说明:多个HandlerMapping的执行顺序问题:
DefaultAnnotationHandlerMapping的order属性&#20540;是:0
&mvc:resources/&&自动注册的&SimpleUrlHandlerMapping的order属性&#20540;是:&
&mvc:default-servlet-handler/&自动注册&的SimpleUrlHandlerMapping&的order属性&#20540;是:&
spring会先执行order&#20540;比较小的。当访问一个a.jpg图片文件时,先通过&DefaultAnnotationHandlerMapping&来找处理器,一定是找不到的,我们没有叫a.jpg的Action。再&按order&#20540;升序找,由于最后一个&SimpleUrlHandlerMapping&是匹配&/**&的,所以一定会匹配上,再响应图片。
访问一个图片,还要走层层匹配。真不知性能如何?改天做一下压力测试,与Apache比一比。
最后再说明一下,&如何你的DispatcherServlet拦截 *.do这样的URL后缀,就不存上述问题了。还是有后缀方便。
八、请求如何映射到具体的Action中的方法?
方案一:基于xml配置映射,可以利用SimpleUrlHandlerMapping、BeanNameUrlHandlerMapping进行Url映射和拦截请求。
配置方法略。
方案二:基于注解映射,可以使用DefaultAnnotationHandlerMapping。
&class=&org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping&&&&&&
但前面我们配置了&mvc:annotation-driven /&,他会自动注册这个bean,就不须要我们显示的注册这个bean了。&&
如何替换&&mvc:annotation-driven /&?他到底做了什么工作,请看,最后面的 十九节&&mvc:annotation-driven /&&到底做了什么工作。
以上都可以注入interceptors,实现权限控制等前置工作。
我们使用第2种,基于注解来使用spring MVC
&并在action类上使用:
@Controller
@RequestMapping(&/user&)
九、Spring中的拦截器:
Spring为我们提供了:
org.springframework.web.servlet.HandlerInterceptor接口,
org.springframework.web.servlet.handler.HandlerInterceptorAdapter适配器,
实现这个接口或继承此类,可以非常方便的实现自己的拦截器。
有以下三个方法:
Action之前执行:
&public boolean preHandle(HttpServletRequest request,
&& HttpServletResponse response, Object handler);
生成视图之前执行
&public void postHandle(HttpServletRequest request,
&& HttpServletResponse response, Object handler,
&& ModelAndView modelAndView);
最后执行,可用于释放资源
&public void afterCompletion(HttpServletRequest request,
&& HttpServletResponse response, Object handler, Exception ex)
分别实现预处理、后处理(调用了Service并返回ModelAndView,但未进行页面渲染)、返回处理(已经渲染了页面)&
在preHandle中,可以进行编码、安全控制等处理;&
在postHandle中,有机会修改ModelAndView;&
在afterCompletion中,可以根据ex是否为null判断是否发生了异常,进行日志记录。&
参数中的Object handler是下一个拦截器。
十、如何使用拦截器?
自定义一个拦截器,要实现HandlerInterceptor接口:
Java代码&&
public&class&MyInteceptor&implements&HandlerInterceptor&{&&&&&
&&&&略。。。&&
Spring MVC并没有总的拦截器,不能对所有的请求进行前后拦截。
Spring MVC的拦截器,是属于HandlerMapping级别的,可以有多个HandlerMapping ,每个HandlerMapping可以有自己的拦截器。
当一个请求按Order&#20540;从小到大,顺序执行HandlerMapping接口的实现类时,哪一个先有返回,那就可以结束了,后面的HandlerMapping就不走了,本道工序就完成了。就转到下一道工序了。
拦截器会在什么时候执行呢? 一个请求交给一个HandlerMapping时,这个HandlerMapping先找有没有处理器来处理这个请求,如何找到了,就执行拦截器,执行完拦截后,交给目标处理器。
如果没有找到处理器,那么这个拦截器就不会被执行。
在spring MVC的配置文件中配置有三种方法:
方案一,(近&#20284;)总拦截器,拦截所有url
Java代码&&
&&&&mvc:interceptors&&&
&&&&&bean&class=&com.app.mvc.MyInteceptor&&/&&&
&/mvc:interceptors&&&
为什么叫“近&#20284;”,前面说了,Spring没有总的拦截器。
&mvc:interceptors/&会为每一 个HandlerMapping,注入一个拦截器。总有一个HandlerMapping是可以找到处理器的,最多也只找到一个处理器,所以这个拦截器总会被执行的。起到了总拦截器的作用。
方案二,&(近&#20284;)&总拦截器,&拦截匹配的URL。
&&&&&&&&&path=&/user/*&&&&&&&
&&&&&&&&&class=&com.mvc.MyInteceptor&&&&&
就是比&方案一多了一个URL匹配。
方案三,HandlerMappint上的拦截器
&class=&org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping&&&&&&&&
&&name=&interceptors&&&&&&&&
&&&&&&&&&&&&
&&&&&&&&&&class=&com.mvc.MyInteceptor&&&&&&&
&&&&&&&&&&&&
&&如果使用了&mvc:annotation-driven /&,&它会自动注册DefaultAnnotationHandlerMapping 与AnnotationMethodHandlerAdapter 这两个bean,所以就没有机会再给它注入interceptors属性,就无法指定拦截器。
当然我们可以通过人工配置上面的两个Bean,不使用&&mvc:annotation-driven /&,就可以&给interceptors属性&注入拦截器了。
其实我也不建议使用&&mvc:annotation-driven /&,而建议手动写详细的配置文件,来替代&&mvc:annotation-driven /&,这就控制力就强了。
如何替换&&mvc:annotation-driven /&?他到底做了什么工作,请看,最后面的 十九节&&mvc:annotation-driven /&&到底做了什么工作。
十一、如何实现全局的异常处理?
在spring MVC的配置文件中:
&id=&exceptionResolver&&class=&org.springframework.web.servlet.handler.SimpleMappingExceptionResolver&&&
&&&&&name=&defaultErrorView&&&&&
&&&&&&&&/error/error&&
&&&&&name=&defaultStatusCode&&&&&
&&&&&&&&500&&
&name=&warnLogCategory&&&&&
&&&&&&&&org.springframework.web.servlet.handler.SimpleMappingExceptionResolver&&
这里主要的类是SimpleMappingExceptionResolver类,和他的父类AbstractHandlerExceptionResolver类。
具体可以配置哪些属性,我是通过查看源码知道的。
你也可以实现HandlerExceptionResolver接口,写一个自己的异常处理程序。spring的扩展性是很好的。
通过SimpleMappingExceptionResolver我们可以将不同的异常映射到不同的jsp页面(通过exceptionMappings属性的配置)。
同时我们也可以为所有的异常指定一个默认的异常提示页面(通过defaultErrorView属性的配置),如果所抛出的异常在exceptionMappings中没有对应的映射,则Spring将用此默认配置显示异常信息。
注意这里配置的异常显示界面均仅包括主文件名,至于文件路径和后缀已经在viewResolver中指定。如/error/error表示/error/error.jsp
显示错误的jsp页面:
Html代码&&
%@&page&language=&java&&contentType=&text/&charset=GBK&&&
&&&&pageEncoding=&GBK&%&&
%@&page&import=&java.lang.Exception&%&&
&!DOCTYPE&html&PUBLIC&&-//W3C//DTD&HTML&4.01&Transitional//EN&&&http://www.w3.org/TR/html4/loose.dtd&&&
&http-equiv=&Content-Type&&content=&text/&charset=GBK&&&
错误页面&&
Exception&e&=&(Exception)request.getAttribute(&exception&);&&
out.print(e.getMessage());&&
其中一句:request.getAttribute(&exception&),key是exception,也是在SimpleMappingExceptionResolver类默认指定的,是可能通过配置文件修改这个&#20540;的,大家可以去看源码。
&参考文章:
十二、如何把全局异常记录到日志中?
在前的配置中,其中有一个属性warnLogCategory,&#20540;是“SimpleMappingExceptionResolver类的全限定名”。我是在SimpleMappingExceptionResolver类父类AbstractHandlerExceptionResolver类中找到这个属性的。查看源码后得知:如果warnLogCategory不为空,spring就会使用apache的mons.logging.Log日志工具,记录这个异常,级别是warn。
&#20540;:“org.springframework.web.servlet.handler.SimpleMappingExceptionResolver”,是“SimpleMappingExceptionResolver类的全限定名”。这个&#20540;不是随便写的。&&因为我在log4j的配置文件中还要加入log4j.logger.org.springframework.web.servlet.handler.SimpleMappingExceptionResolver=WARN,保证这个级别是warn的日志一定会被记录,即使log4j的根日志级别是ERROR。
&十三、如何给spring3 MVC中的Action做JUnit单元测试?
&使用了spring3 MVC后,给action做单元测试也很方便,我以前从来不给action写单元测试的,再在不同了,方便了,所以一定要写。
&JUnitActionBase类是所有JUnit的测试类的父类
Java代码&&
package&&&
import&javax.servlet.http.HttpServletR&&
import&javax.servlet.http.HttpServletR&&
import&org.junit.BeforeC&&
import&org.springframework.mock.web.MockServletC&&
import&org.springframework.web.context.WebApplicationC&&
import&org.springframework.web.context.support.XmlWebApplicationC&&
import&org.springframework.web.servlet.HandlerA&&
import&org.springframework.web.servlet.HandlerExecutionC&&
import&org.springframework.web.servlet.HandlerM&&
import&org.springframework.web.servlet.ModelAndV&&
import&org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerA&&
import&org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerM&&
public&class&JUnitActionBase&{&&
&&&&private&static&HandlerMapping&handlerM&&
&&&&private&static&HandlerAdapter&handlerA&&
&&&&@BeforeClass&&
&public&static&void&setUp()&{&&
&&&&&&&&if&(handlerMapping&==&null)&{&&
&&&&&&&&&&&&String[]&configs&=&{&&file:src/springConfig/springMVC.xml&&};&&
&&&&&&&&&&&&XmlWebApplicationContext&context&=&new&XmlWebApplicationContext();&&
&&&&&&&&&&&&context.setConfigLocations(configs);&&
&&&&&&&&&&&&MockServletContext&msc&=&new&MockServletContext();&&
&&&&&&&&&&&&context.setServletContext(msc);&&&&&&&&&context.refresh();&&
&&&&&&&&&&&&msc.setAttribute(WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE,&context);&&
&&&&&&&&&&&&handlerMapping&=&(HandlerMapping)&context&&
&&&&&&&&&&&&&&&&&&&&.getBean(DefaultAnnotationHandlerMapping.class);&&
&&&&&&&&&&&&handlerAdapter&=&(HandlerAdapter)&context.getBean(context.getBeanNamesForType(AnnotationMethodHandlerAdapter.class)[0]);&&&&&
&&&&&&&&}&&
&&&&public&ModelAndView&excuteAction(HttpServletRequest&request,&HttpServletResponse&response)&&
&throws&Exception&{&&
&&&&&&&&HandlerExecutionChain&chain&=&handlerMapping.getHandler(request);&&
&&&&&&&&final&ModelAndView&model&=&handlerAdapter.handle(request,&response,&&
&&&&&&&&&&&&&&&&chain.getHandler());&&
&&&&&&&&return&&&
这是个JUnit测试类,我们可以new Request对象,来参与测试,太方便了。给request指定访问的URL,就可以请求目标Action了。
Java代码&&
package&.app.&&
import&org.junit.A&&
import&org.junit.T&&
import&org.springframework.mock.web.MockHttpServletR&&
import&org.springframework.mock.web.MockHttpServletR&&
import&org.springframework.web.servlet.ModelAndV&&
import&test.JUnitActionB&&
public&class&TestOrderAction&extends&JUnitActionBase&{&&
&&&&@Test&&
&&&&public&void&testAdd()&throws&Exception&{&&
&&&&MockHttpServletRequest&request&=&new&MockHttpServletRequest();&&
&&&&&&&&MockHttpServletResponse&response&=&new&MockHttpServletResponse();&&
&&&&&&&&request.setServletPath(&/order/add&);&&
&&&&&&&&request.addParameter(&id&,&&1002&);&&
&&&&&&&&request.addParameter(&date&,&&&);&&
&&&&&&&&request.setMethod(&POST&);&&
&&&&&&&&&&
&&&&&&&&final&ModelAndView&mav&=&this.excuteAction(request,&response);&&
&&&&&&&&&&
&&&&&&&&Assert.assertEquals(&order/add&,&mav.getViewName());&&
&&&&&&&&String&msg=(String)request.getAttribute(&msg&);&&
&&&&&&&&System.out.println(msg);&&
&需要说明一下&:由于当前最想版本的Spring(Test) 3.0.5还不支持@ContextConfiguration的注解式context file注入,所以还需要写个setUp处理下,否则类&#20284;于Tiles的加载过程会有错误,因为没有ServletContext。3.1的版本应该有更好的解决方案,参见:&。
&十四、转发与重定向
可以通过redirect/forward:url方式转到另一个Action进行连续的处理。
可以通过redirect:url 防止表单重复提交&。
写法如下:
return &forward:/order/add&;
return &redirect:/index.jsp&;
&十五、处理ajax请求
1、引入下面两个jar包,我用的是1.7.2,好像1.4.2版本以上都可以,下载地址:
jackson-core-asl-1.7.2.jar&
jackson-mapper-asl-1.7.2.jar
2、spring的配置文件中要有这一行,才能使用到spring内置支持的json转换。如果你手工把POJO转成json就可以不须要使用spring内置支持的json转换。
&mvc:annotation-driven /&
3、使用@ResponseBody注解
Java代码&&
@RequestMapping(&/ajax&)&&
@ResponseBody&&
public&Object&ajax(HttpServletRequest&request){&&
&&&&List&String&&list=new&ArrayList&String&();&&
&&&&list.add(&电视&);&&
&&&&&&&list.add(&洗衣机&);&&
&&&&list.add(&冰箱&);&&
&&&&list.add(&电脑&);&&
&&&&list.add(&汽车&);&&
&&&&list.add(&空调&);&&
&&&&list.add(&自行车&);&&
&&&&list.add(&饮水机&);&&
&&&&list.add(&热水器&);&&
&&&&return&&&
转载请注明出处:本文地址:
十六、关于写几个配置文件的说明&
我看到有的人把配置文件写两份:
一个是原有的applicationContext.xml,这个文件从spring2.0-2.5时一直在使用。
别一个是新加的spring MVC的配置文件。
其实这两个文件是可以写成一个文件的,springMVC相关的配置,数据源,事务相关配置可以都写再一个配置文件中。
本例子中只使用了一个spring配置文件叫“springMVC.xml”。
就不要再多配置一个applicationContext.xml文件了。
web.xml文件中也不要再配置org.springframework.web.context.ContextLoaderListener的listener了。
写两个配置文件spring会扫描两次。
写两个配置文件还出现事务不好使的现象,是当把@Transactional写有Action层时出现的。
如果写两个配置文件,先执行springMVC.xml(xxx-servlet.xml),后执行applicationContext.xml。
先执行springMVC.xml(xxx-servlet.xml)时,由于数据源、事务都配置在applicationContext.xml中,还没有执行(未准备好), 所以导致了上面的问题。
十七、如何取得Spring管理的bean&(请用第3种方法)
1、servlet方式加载时,
【web.xml】
springMVC&&
org.springframework.web.servlet.DispatcherServlet&&
contextConfigLocation&&
classpath*:/springMVC.xml&&
&spring容器放在ServletContext中的key是org.springframework.web.servlet.FrameworkServlet.CONTEXT.springMVC
注意后面的springMVC,是你的servlet-name配置的&#20540;,注意适时修改。
Java代码&&
ServletContext&sc=略&&
WebApplicationContext&attr&=&(WebApplicationContext)sc.getAttribute(&org.springframework.web.servlet.FrameworkServlet.CONTEXT.springMVC&);&&
2、listener方式加载时:
【web.xml】
&&contextConfigLocation&&
&&/WEB-INF/applicationContext&&
&&org.springframework.web.context.ContextLoaderListener&&
&【jsp/servlet】可以这样取得
Java代码&&
ServletContext&context&=&getServletContext();&&
WebApplicationContext&applicationContext&&=&WebApplicationContextUtils&.getWebApplicationContext(context);&&&
3、通用的方法来了,神器啊,前的& 1、2两种方法并不通用,可以抛弃了。
在配置文件中加入:
&class=&com.xxxxx.SpringContextHolder&&lazy-init=&false&&&&
Java代码&&
import&org.springframework.context.ApplicationC&&
import&org.springframework.context.ApplicationContextA&&
public&class&SpringContextHolder&implements&ApplicationContextAware&{&&
private&static&ApplicationContext&applicationC&&
public&void&setApplicationContext(ApplicationContext&applicationContext)&{&&
SpringContextHolder.applicationContext&=&applicationC&&&
public&static&ApplicationContext&getApplicationContext()&{&&
checkApplicationContext();&&
return&applicationC&&
@SuppressWarnings(&unchecked&)&&
public&static&&T&&T&getBean(String&name)&{&&
checkApplicationContext();&&
return&(T)&applicationContext.getBean(name);&&
@SuppressWarnings(&unchecked&)&&
public&static&&T&&T&getBean(Class&T&&clazz)&{&&
checkApplicationContext();&&
return&(T)&applicationContext.getBeansOfType(clazz);&&
public&static&void&cleanApplicationContext()&{&&
applicationContext&=&null;&&
private&static&void&checkApplicationContext()&{&&
if&(applicationContext&==&null)&{&&
throw&new&IllegalStateException(&applicaitonContext未注入,请在applicationContext.xml中定义SpringContextHolder&);&&
十八、多视图控制器
当有jsp,flt (模板)等多种页面生成展示方式时,spring默认使用的是“视图解析器链”。 真是一个链,所以性能不好,spring会在“视图解析器链”中顺序的查找,直到找到对应的 “视图解析器” 。jsp视图解析器一定要写在最后面,因为一旦调用jsp,就向浏览器发出数据了,Spring就没有机会再尝试下一个了。
所以自己写一个&多视图解析器&,依靠扩展名来区分,可一次准确的选中一个 视图解析器,提高性能(会有多少提高呢?没测试过).
下面的例子支持jsp,flt (模板)两种页面生成展示方式,你中以自己添加,支持更多。
&&&&class=&com.xxx.core.web.MixedViewResolver&&&
&&&&&name=&resolvers&&&
&&&&&&&&&&
&&&&&&&&&&&&&key=&jsp&&&
&&&&&&&&&&&&&&&&&class=&org.springframework.web.servlet.view.InternalResourceViewResolver&&&
&&&&&&&&&&&&&&&&&&&&&name=&prefix&&value=&/WEB-INF/jsp/&&&
&&&&&&&&&&&&&&&&&&&&&name=&viewClass&&value=&org.springframework.web.servlet.view.JstlView&&&
&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&
&&&&&&&&&&&&&key=&ftl&&&
&&&&&&&&&&&&&&&&&class=&org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver&&&
&&&&&&&&&&&&&&&&&&&&&name=&cache&&value=&true&&&
&&&&&&&&&&&&&&&&&&&&&name=&contentType&&value=&text/charset=UTF-8&&&
&&&&&&&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&&&&&name=&exposeSpringMacroHelpers&&value=&true&&&
&&&&&&&&&&&&&&&&&&&&&name=&viewClass&&value=&org.springframework.web.servlet.view.freemarker.FreeMarkerView&&&
&&&&&&&&&&&&&&&&&&&&&name=&requestContextAttribute&&value=&rc&&&
&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&
&&&&&&&&&&
&&&&id=&freeMarkerConfigurer&&class=&org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer&&&&
&&&&&&&&name=&templateLoaderPath&&value=&/WEB-INF/ftl/&&&&&
&&&&&&&&name=&freemarkerSettings&&&&
&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&key=&template_update_delay&5&&&
&&&&&&&&&&&&&&&&key=&default_encoding&UTF-8&&&
&&&&&&&&&&&&&&&&key=&locale&zh_CN&&&
&&&&&&&&&&&&&&
&&&&&&&&&&
Java代码&&
import&java.util.L&&
import&java.util.M&&
import&org.springframework.web.servlet.V&&
import&org.springframework.web.servlet.ViewR&&
public&class&MixedViewResolver&implements&ViewResolver{&&
&&&&private&Map&String,ViewResolver&&&&
&&&&public&void&setResolvers(Map&String,&ViewResolver&&resolvers)&{&&
&&&&&&&&this.resolvers&=&&&
&&&&public&View&resolveViewName(String&viewName,Locale&locale)&throws&Exception{&&
&&&&&&&&int&n=viewName.lastIndexOf(&.&);&&
&&&&&&&&if(n!=-1){&&
&&&&&&&&&&&&&&
&&&&&&&&&&&&String&suffix=viewName.substring(n&#43;1);&&
&&&&&&&&&&&&&&
&&&&&&&&&&&&ViewResolver&resolver=resolvers.get(suffix);&&
&&&&&&&&&&&&if(resolver==null){&&
&&&&&&&&&&&&&&&&throw&new&RuntimeException(&No&ViewResolver&for&&&#43;suffix);&&
&&&&&&&&&&&&}&&
&&&&&&&&&&&&return&&resolver.resolveViewName(viewName,&locale);&&
&&&&&&&&}else{&&
&&&&&&&&&&&&ViewResolver&resolver=resolvers.get(&jsp&);&&
&&&&&&&&&&&&return&&resolver.resolveViewName(viewName,&locale);&&
&&&&&&&&}&&
十九、&&mvc:annotation-driven /&&到底做了什么工作
一句&&mvc:annotation-driven /&实际做了以下工作:(不包括添加自己定义的拦截器)
我们了解这些之后,对Spring3 MVC的控制力就更强大了,想改哪就改哪里。
&&&&class=&org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping&&&&&&&&&&&
&&&&&name=&interceptors&&&
&&&&&&&&&&&&
&&&&&&&&&&&&&bean=&logNDCInteceptor&&&&&&
&&&&&&&&&&&&&bean=&myRequestHelperInteceptor&&&&&&&
&&&&&&&&&&&&&bean=&myPermissionsInteceptor&&&&&&
&&&&&&&&&&&&&bean=&myUserInfoInteceptor&&&&&&
&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&
&class=&org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter&&&
&&&&&name=&messageConverters&&&&&
&&&&&&&&&&&&
&&&&&&&&&&&&&bean=&byteArray_hmc&&&&&&
&&&&&&&&&&&&&bean=&string_hmc&&&&&&
&&&&&&&&&&&&&bean=&resource_hmc&&&&&&
&&&&&&&&&&&&&bean=&source_hmc&&&&&&
&&&&&&&&&&&&&bean=&xmlAwareForm_hmc&&&&&&
&&&&&&&&&&&&&bean=&jaxb2RootElement_hmc&&&&&&
&&&&&&&&&&&&&bean=&jackson_hmc&&&&&&
&&&&&&&&&&&&
&id=&byteArray_hmc&&class=&org.springframework.http.converter.ByteArrayHttpMessageConverter&&&&
&id=&string_hmc&&class=&org.springframework.http.converter.StringHttpMessageConverter&&&&
&id=&resource_hmc&&class=&org.springframework.http.converter.ResourceHttpMessageConverter&&&&
&id=&source_hmc&&class=&org.springframework.http.converter.xml.SourceHttpMessageConverter&&&&
&id=&xmlAwareForm_hmc&&class=&org.springframework.http.converter.xml.XmlAwareFormHttpMessageConverter&&&&
&id=&jaxb2RootElement_hmc&&class=&org.springframework.http.converter.xml.Jaxb2RootElementHttpMessageConverter&&&&
&id=&jackson_hmc&&class=&org.springframework.http.converter.json.MappingJacksonHttpMessageConverter&&&&
二十、 本文中springMVC.xml配置文件是核心,这里给一个下载地址
要在/网站有注册帐号才能下载
下载次数: 47
分享到:&&
浏览 34888
关于双亲上下文那里有点问题啊
/t/516563/Spring/DispatcherServlet-vs-ContextLoaderListener
/2011/10/difference-between-loading-context-via-dispatcherservlet-and-contextloaderlistener/
楼主你能不能再写一篇文章介绍 视图啊?&&&
&!-- 视图解释类 --&&&
&& &bean class=&org.springframework.web.servlet.view.InternalResourceViewResolver&&&&
&&& &property name=&prefix& value=&/WEB-INF/jsp/&/&&&
&&& &property name=&suffix& value=&.jsp&/&
&& &/bean&&&
以后会的, 现在太忙,公司事儿太多了,现在主要精力在做网络通信。
在方法中使用注解为什么会出现
No mapping found for HTTP request with URI [/SpringTest1/] in DispatcherServlet with name 'appServlet'
找不到appServlet这个controler,对着requestmapping找找对吗
&&&&&&&&default&&
&&&&&&&&*.jpg&&
&&&&&&&&default&&
&&&&&&&&*.js&&
&&&&&&&&default&&
&&&&&&&&*.css&&
这样写感觉不太好,我都放到一个文件夹下面,用下面这样怎么不行呢?
&&&&default&&
&&&&/resources/*&&
我觉得既然是默认,它内部就默认了路径,你给加上路径了,可能是找不到了。
后缀还是很重要的, action的url加上.do一切都解决了。
在Action上做单元测试,是不是有点过于测试了。
在Service层或者是 Models 进行测试就可以了?
是,没必要测
&&&&&&&&default&&
&&&&&&&&*.jpg&&
&&&&&&&&default&&
&&&&&&&&*.js&&
&&&&&&&&default&&
&&&&&&&&*.css&&
这样写感觉不太好,我都放到一个文件夹下面,用下面这样怎么不行呢?
&&&&default&&
&&&&/resources/*&&
我觉得既然是默认,它内部就默认了路径,你给加上路径了,可能是找不到了。
&&&&&&&&default&&
&&&&&&&&*.jpg&&
&&&&&&&&default&&
&&&&&&&&*.js&&
&&&&&&&&default&&
&&&&&&&&*.css&&
这样写感觉不太好,我都放到一个文件夹下面,用下面这样怎么不行呢?
&&&&default&&
&&&&/resources/*&&
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:307449次
积分:4272
积分:4272
排名:第4809名
原创:80篇
转载:100篇
评论:61条
(3)(2)(5)(1)(1)(2)(6)(2)(3)(1)(1)(1)(2)(1)(3)(2)(1)(2)(4)(11)(1)(15)(4)(6)(6)(2)(1)(1)(2)(9)(4)(7)(5)(10)(7)(2)(1)(15)(8)(3)(3)(5)(1)(1)(6)(2)}

我要回帖

更多关于 联想a788t格机 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信