Apache Shiro Schnellstart Teil 2

Beim letzten Mal habe ich das Beispiel so verschoben, wie es ist, aber ich glaube nicht, dass die Benutzerinformationen direkt in die Einstellungsdatei geschrieben sind. http://qiita.com/namikitakeo/items/fc593526fd354a381fbd

[users]
# format: username = password, role1, role2, ..., roleN
root = secret,admin
guest = guest,guest
presidentskroob = 12345,president
darkhelmet = ludicrousspeed,darklord,schwartz
lonestarr = vespa,goodguy,schwartz

[roles]
# format: roleName = permission1, permission2, ..., permissionN
admin = *
schwartz = lightsaber:*
goodguy = winnebago:drive:eagle5

Hier finden Sie Benutzerinformationen aus der Datenbank. Ich benutze Apache Derby, weil es nicht so gut ist wie MySQL. https://nhachicha.wordpress.com/2012/06/30/mysql-apache-derby-as-jdbcrealm-for-apache-shiro/

Starten Sie den Apache Derby-Dienst.

$ sudo su -
# cd /usr/share/derby
# ./NetworkServerControl start

Erstellen Sie eine Benutzerinformationsdatenbank.

$ ij
ij> connect 'jdbc:derby://localhost:1527/test;create=true';
ij> CREATE TABLE USERS (ID varchar(255) PRIMARY KEY NOT NULL, PASS varchar(255) NOT NULL);
ij> CREATE TABLE ROLES (ID varchar(255) PRIMARY KEY NOT NULL, ROLE varchar(255) NOT NULL);
ij> INSERT INTO USERS (ID,PASS) VALUES ('root','password');
ij> INSERT INTO ROLES (ID,ROLE) VALUES ('root','admin');

Wechseln Sie in das Webverzeichnis.

$ cd shiro-root-1.3.2/samples/web

Ändern Sie shiro.ini wie folgt.

jdbcRealm=org.apache.shiro.realm.jdbc.JdbcRealm
jdbcRealm.authenticationQuery = select pass from users where id = ?
jdbcRealm.userRolesQuery = select role from roles where id = ?

ds = com.jolbox.bonecp.BoneCPDataSource
ds.driverClass=org.apache.derby.jdbc.ClientDriver
ds.jdbcUrl=jdbc:derby://localhost:1527/test
jdbcRealm.dataSource=$ds

# We need to set the cipherKey, if you want the rememberMe cookie to work after restarting or on multiple nodes.
# YOU MUST SET THIS TO A UNIQUE STRING
#securityManager.rememberMeManager.cipherKey = kPH+bIxk5D2deZiIxcaaaA==

#[users]
# format: username = password, role1, role2, ..., roleN
#root = secret,admin
#guest = guest,guest
#presidentskroob = 12345,president
#darkhelmet = ludicrousspeed,darklord,schwartz
#lonestarr = vespa,goodguy,schwartz

#[roles]
# format: roleName = permission1, permission2, ..., permissionN
#admin = *
#schwartz = lightsaber:*
#goodguy = winnebago:drive:eagle5

Fügen Sie pom.xml eine Abhängigkeit hinzu, wie unten gezeigt.

<dependency>
    <groupId>com.jolbox</groupId>
    <artifactId>bonecp</artifactId>
    <version>0.7.1.RELEASE</version>
</dependency>
<dependency>
    <groupId>org.apache.derby</groupId>
    <artifactId>derbyclient</artifactId>
    <version>10.4.2.0</version>
</dependency>

Führen Sie Jetty aus.

$ mvn jetty:run

Bitte beziehen Sie sich mit einem WEB-Browser auf die folgende URL. http://localhost:9080/

Recommended Posts

Apache Shiro Schnellstart Teil 2
Apache Hadoop und Java 9 (Teil 1)
Zusammenfassung der Übersetzung des Apache Shiro-Tutorials