1.解壓
修改文件名為mongo3.2.5,執行命令如下:
mv mongodb-linux-i686-3.2.5 mongo3.2.5
2.創建組mongoDB與用戶mongoDB、文件夾data以及log
用于與組是為了便于管理MongoDB
data用于存放mongoDB數據。
log用于記錄mongoDB日志。
3.指定組、用戶
4.啟動mongo服務命令
bin/mongod --dbpath=/usr/local/mongo-3.25/data/ --logpath=/usr/local/mongo-3.25/log/mongo.log --journal --storageEngine=mmapv1
注意:因為我使用的是linux32位系統的,故默認的存儲引擎wiredTiger是不支持的。需要指定存儲引擎。如果不指定可能會報以下錯誤:
開啟MongoDB服務成功后,截圖如下:
連接mongo服務
上面啟動MongoDB之后,需要重新打開一個窗口,進行連接。
當提示如下信息,代表連接成功。
當然,也可以通過瀏覽器訪問以下網址,查看輸出結果
http://192.168.153.140:27017
初始安裝的時候沒有admin數據庫
開啟認證
修改配置文件/etc/MongoDB.conf
打開auth的注釋,設置為auth = true
重啟mongodb
sudo service mongodb restart
添加管理員
使用命令mongo進入命令行
創建第一個用戶,該用戶需要有用戶管理權限
這里設置其角色為root
use admin
db.createUser({user:"admin",pwd:"password",roles:["root"]})
新增的用戶在system.users中
> db.getCollectionNames()
[ "system.indexes", "system.users", "system.version" ]
第一個用戶添加完成后,便需要認證才能繼續添加其他用戶
使用db.auth("admin", "password")認證
添加數據庫用戶
為其他數據庫添加用戶,添加用戶前需要切換到該數據庫
這里設置其角色為dbOwner
use testdb1
db.createUser({user: "testdb1u1", pwd: "xyz123", roles: [{ role: "dbOwner", db: "testdb1" }]})
查看用戶
> use admin
switched to db admin
> db.system.users.find()
{ "_id" : "admin.admin", "user" : "admin", "db" : "admin", "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "Fdh2ldIW3Aw8Cxz9Dt+96g==", "storedKey" : "zbkfj6ZQH1xwGoOg8JJ6OjtR3Cs=", "serverKey" : "yqkqHABZ64rEeq1X0htOAtUnwFU=" } }, "roles" : [ { "role" : "root", "db" : "admin" } ] }
{ "_id" : "testdb1.testdb1u1", "user" : "testdb1u1", "db" : "testdb1", "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "Xxt2uET3jRtAYVigyLUydw==", "storedKey" : "yinLG61nRFzfC+3NtB5p9RR+avM=", "serverKey" : "OX/Pdft7JWJm/g0jg07q49OC4c8=" } }, "roles" : [ { "role" : "dbOwner", "db" : "testdb1" } ] }
參考地址:
spring-servlet.xml 中加入 <import resource="ApplicationContext.xml" />
ApplicationContext.xml 中把其它的xml文件import進來
web.xml
SpringMVC核心分發器 加入參數 <param-value>classpath:spring-mvc.xml</param-value>
不加載 <param-value>classpath*:/spring-context*.xml</param-value>
controller/service等都在mvc中加載
<context:component-scan base-package="com.mweb.**.controller" />
<context:component-scan base-package="com.mweb.**.service" />。。。。需要加載的@Component等
加入:
<aop:aspectj-autoproxy proxy-target-class="true" />
二、spring-context*.xml / spring-mvc.xml 分開加載掃描的方法
web.xml 中:
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:/spring-context*.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> 必須加入才行
</listener>
<servlet>
<servlet-name>spring</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
spring-mvc.xml 中:
<context:component-scan base-package="com.mweb.**.controller" /> 掃描 controller
<aop:aspectj-autoproxy /> aop 參考下面的也行
- <aop:aspectj-autoproxy proxy-target-class="true">
- <aop:include name="controllerAspect"/> @Aspect聲明的類
- </aop:aspectj-autoproxy>
<context:component-scan base-package="com.mweb.**.extension,
com.mweb.**.service,
com.mweb.base.aspect,
com.mweb.base.shiro.realm" />
<aop:aspectj-autoproxy proxy-target-class="true" />
這樣就可以了
/*多條-刪除*/
function deleteBatch(){
layer.confirm('確認要刪除嗎?',function(index){
var idList = new Array();
// 獲得選中的ID值
$("input[name='id']:checkbox:checked").each(function(){
idList.push(this.value);
});
$.ajax({
type:"post",
url:"${CONTEXT_PATH}/sys/menu/deletebatch.html",
data: $('#form-menu').serialize(),//表單數據
data: {"idList":idList},
//cache:false,
success:function(msg){
if(msg=="success"){
// 延時1S刷新
setTimeout('location.replace(location.href)', 1000);
layer.msg('全部刪除成功!',{icon:1,time:1000});
}
if(msg=="error"){
layer.msg('異常!');
}
}
});
});
}
后臺controller:
@RequiresPermissions("sys:menu:edit")
@ResponseBody
@RequestMapping("/deletebatch")
public String deletebatch(@RequestParam("idList[]") List<String> objs,ModelMap modelMap, HttpServletRequest request) throws Exception {
String retStr = "error";
try{
menuService.removeMulti(objs);
retStr = "success" ;
}catch(Exception e) {
logger.info(e.getMessage());
}
return retStr;
}
后臺service:
@CacheEvict(value="defaultCache",allEntries=true)
public void removeMulti(List<String> objs) {
BasicDBList basicDBList=new BasicDBList();
for(String id : objs) {
basicDBList.add(new BasicDBObject("id",id));
}
DBObject obj =new BasicDBObject();
obj.put("$or", basicDBList);
Query query=new BasicQuery(obj);
mongoTemplate.remove(query,Menu.class);
}
/** ajax登錄,并jquery md5 加密密碼 */
function loginsubmit() {
var salt=$("#username").val();
var pwd=$("#password").val();
var md5Pwd=$.md5(pwd+salt);
var validateCode=$("#validateCode").val();
var rememberMe=$("#rememberMe").val();
data="username="+ salt
+ "&password=" + md5Pwd
+ "&validateCode=" + validateCode
+ "&rememberMe=" + rememberMe;
$.ajax({
type: "POST",
url: "loginsubmit",
dataType:'html',
data: data,
contentType:"application/x-www-form-urlencoded;charset=UTF-8",
success: function(msg){
if(msg=="ok") {
location.href = "index";
}else if (msg=="errorcode"){
alert("驗證碼無效!");
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(XMLHttpRequest.status);
alert(XMLHttpRequest.readyState);
alert(textStatus);
}
});
}
以上代碼中url為 loginsubmit.html 去掉".html"即可提交 ,后臺代碼用的@ResponseBody注解
<property name="unauthorizedUrl" value="/sys/unauthorized"/> 不起作用
spring-mvc.xml 中加入:
<!-- 異常處理 -->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<prop key="org.apache.shiro.authz.UnauthorizedException">jsp/unauthorized</prop>
<prop key="org.apache.shiro.authz.UnauthenticatedException">jsp/unauthorized</prop>
<prop key="org.apache.shiro.authz.AuthorizationException">jsp/unauthorized</prop>
<prop key="java.lang.Throwable">jsp/unauthorized</prop>
</props>
</property>
</bean>
如果還不能解決:可以看一下web.xml中是否有:
<error-page>
<error-code>400</error-code>
<location>/WEB-INF/template/common/errorPage.jsp</location>
</error-page>
<error-page>
<error-code>404</error-code>
<location>/WEB-INF/template/common/errorPage.jsp</location>
</error-page>
<error-page>
<error-code>500</error-code>
<location>/sys/unauthorized.html</location>
</error-page>
都屏蔽掉,應該就好了
在context.xml 中加入紅色的
<WatchedResource>WEB-INF/web.xml</WatchedResource>
<WatchedResource>${catalina.base}/conf/web.xml</WatchedResource>
<Resources cachingAllowed="true" cacheMaxSize="100000" />