1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19 package org.apache.shiro.aspectj;
20
21 import org.apache.shiro.authz.annotation.RequiresAuthentication;
22 import org.apache.shiro.authz.annotation.RequiresGuest;
23 import org.apache.shiro.authz.annotation.RequiresPermissions;
24 import org.apache.shiro.authz.annotation.RequiresUser;
25
26 import java.sql.Timestamp;
27
28
29
30
31
32 public class SecuredDummyService implements DummyService {
33
34 @RequiresAuthentication
35 @RequiresPermissions("dummy:admin")
36 public void change() {
37 retrieve();
38 log("change");
39 peek();
40 }
41
42 public void anonymous() {
43 log("anonymous");
44 }
45
46 @RequiresGuest
47 public void guest() {
48 log("guest");
49 }
50
51 @RequiresUser
52 public void peek() {
53 log("peek");
54 }
55
56 @RequiresPermissions("dummy:user")
57 public void retrieve() {
58 log("retrieve");
59 }
60
61 public void log(String aMessage) {
62 if (aMessage != null) {
63 System.out.println(new Timestamp(System.currentTimeMillis()).toString() + " [" + Thread.currentThread() + "] * LOG * " + aMessage);
64 } else {
65 System.out.println("\n\n");
66 }
67 }
68
69 }