forked from apache/shiro-site
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
8 changed files
with
357 additions
and
310 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
The children of this page contain information which is **included in other pages**. This is a library of re-usable information chunks. | ||
|
||
If you want to change any of these pages, be aware that: | ||
|
||
* Changing page names is problematic — you will need to change all the {include} and {excerpt-include} macros manually. | ||
* The content is used in many places — make sure your change is generic enough to fit the contexts in which the pages are used. | ||
|
||
To include an excerpt from a page: | ||
|
||
``` | ||
{excerpt-include:_page name|nopanel=true} | ||
``` | ||
|
||
Note that the page titled '_page name' must contain the {excerpt} macro, otherwise the {excerpt-include} will not work. | ||
|
||
To include the entire contents of a page" | ||
|
||
``` | ||
{include:page name|nopanel=true} | ||
``` |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
<a name="Introduction-IntroductiontoApacheShiro"></a> | ||
#Introduction to Apache Shiro | ||
|
||
<a name="Introduction-WhatisApacheShiro%3F"></a> | ||
##What is Apache Shiro? | ||
|
||
Apache Shiro is a powerful and flexible open-source security framework that cleanly handles authentication, authorization, enterprise session management and cryptography. | ||
|
||
Apache Shiro's first and foremost goal is to be easy to use and understand. Security can be very complex at times, even painful, but it doesn't have to be. A framework should mask complexities where possible and expose a clean and intuitive API that simplifies the developer's effort to make their application(s) secure. | ||
|
||
Here are some things that you can do with Apache Shiro: | ||
|
||
* Authenticate a user to verify their identity | ||
* Perform access control for a user, such as: | ||
* Determine if a user is assigned a certain security role or not | ||
* Determine if a user is permitted to do something or not | ||
* Use a Session API in any environment, even without web or EJB containers. | ||
* React to events during authentication, access control, or during a session's lifetime. | ||
* Aggregate 1 or more data sources of user security data and present this all as a single composite user 'view'. | ||
* Enable Single Sign On (SSO) functionality | ||
* Enable 'Remember Me' services for user association without login | ||
... | ||
and much more - all integrated into a cohesive easy-to-use API. | ||
|
||
Shiro attempts to achieve these goals for all application environments - from the simplest command line application to the largest enterprise applications, without forcing dependencies on other 3rd party frameworks, containers, or application servers. Of course the project aims to integrate into these environments wherever possible, but it could be used out-of-the-box in any environment. | ||
|
||
<a name="Introduction-ApacheShiroFeatures"></a> | ||
##Apache Shiro Features | ||
|
||
Apache Shiro is a comprehensive application security framework with many features. The following diagram shows where Shiro focuses its energy, and this reference manual will be organized similarly: | ||
|
||
<img src="assets/images/ShiroFeatures.png" style="margin:0px auto;display:block"></img> | ||
|
||
Shiro targets what the Shiro development team calls "the four cornerstones of application security" - Authentication, Authorization, Session Management, and Cryptography: | ||
|
||
* **Authentication:** Sometimes referred to as 'login', this is the act of proving a user is who they say they are. | ||
|
||
* **Authorization:** The process of access control, i.e. determining 'who' has access to 'what'. | ||
|
||
* **Session Management:** Managing user-specific sessions, even in non-web or EJB applications. | ||
|
||
* **Cryptography:** Keeping data secure using cryptographic algorithms while still being easy to use. | ||
|
||
There are also additional features to support and reinforce these concerns in different application environments, especially: | ||
|
||
* Web Support: Shiro's web support APIs help easily secure web applications. | ||
* Caching: Caching is a first-tier citizen in Apache Shiro's API to ensure that security operations remain fast and efficient. | ||
* Concurrency: Apache Shiro supports multi-threaded applications with its concurrency features. | ||
* Testing: Test support exists to help you write unit and integration tests and ensure your code will be secured as expected. | ||
* "Run As": A feature that allows users to assume the identity of another user (if they are allowed), sometimes useful in administrative scenarios. | ||
* "Remember Me": Remember users' identities across sessions so they only need to log in when mandatory. |
Oops, something went wrong.