Working principle and process of the three SSH frameworks)

Source: Internet
Author: User
Tags to domain

Principle:
1. Read and parse the hibernate. cfg. xml configuration file through configuration (). Configure ();
2. The ing information is read and parsed by <Mapping Resource = "com/XX/user. HBM. xml"/> In hibernate. cfg. xml.
3. Create sessionfactory through config. buildsessionfactory (); //
4. sessionfactory. opensession (); // open sesssion
5. session. begintransaction (); // create transaction Transation
6. Persistent operate persistent operation
7. session. gettransaction (). Commit (); // submit the transaction
8. Disable session
9. Disable sesstionfactory

Why:
1. The code for JDBC database access is encapsulated, which greatly simplifies the tedious and repetitive code at the data access layer.

2. Hibernate is a mainstream persistence framework based on JDBC and an excellent ORM implementation. He greatly simplifies the coding of the DaO layer.

3. hibernate uses the Java reflection mechanism instead of the bytecode enhancement program to achieve transparency.

4. hibernate has excellent performance because it is a lightweight framework. The flexibility of ing is excellent. It supports various relational databases, from one-to-one to many-to-many complex relationships.
 
2. How does hibernate delay loading?
1. Implementation of hibernate2 delayed loading: a) object B) Collection)

2. hibernate3 provides the property's delayed Loading Function

When hibernate queries data, the data does not exist in the memory. When the program actually operates on the data, the object exists in the memory, and the loading is delayed, it saves the server memory overhead and improves the server performance.

3. How does one implement the relationship between classes in hibernate? (For example, one-to-many and many-to-many relationships)

The relationship between classes is mainly reflected in the relationship between tables. They operate on objects in a city. In our program, all tables and classes are mapped together, they are used in the configuration file named "allow-to-one", "one-to-allow", "allow-to-allow,

4. Talk about the cache mechanism of Hibernate

1. The internal cache exists in hibernate, which is also called a level-1 cache, which belongs to the application thing-level cache.

2. Secondary cache:
A) Application and Cache
B) distributed cache
Condition: the data is not modified by a third party, the data size is within the acceptable range, the data update frequency is low, the same data is frequently used by the system, non-critical data
C) third-party cache implementation
/////// Level 1 cache: Session-level cache is also called transaction-level cache. It only caches entities, and the lifecycle is consistent with that of sessions. It cannot be managed.

Do not display the call.

Level-2 Cache: sessionfactory cache, also known as process-level cache. It is implemented using the 3rd-party plug-in and also a value-based Cache entity. The lifecycle is consistent with that of sessionfactory and can be managed.

First, configure the 3rd plug-in. We use ehcache and add it to the hibernate. cfg. xml file.

<Property name = "hibernate. cache. user_second_level_cache"> true </property>

Call to be displayed in the ing, <Cache Usage = "read-only"/>

Second-level cache query cache: caches common attributes. If the associated table is modified, the query cache lifecycle ends.

You must manually enable query cache in the program: Query. setcacheable (true );/////////

5. Hibernate query method
SQL, criteria, object comptosition
Hql:
1. query attributes
2. parameter query and name parameter query
3. join query
4. Paging Query
5. Statistical functions

6. How to optimize hibernate?
1. Use bidirectional one-to-Multiple Association instead of unidirectional one-to-Multiple Association
2. flexible use of one-to-multiple associations
3. Replace multiple-to-one instead of one-to-one
4. Configure the object cache without using the set Cache
5. Use bag for one-to-multiple sets and set for multiple-to-multiple sets
6. Use explicit polymorphism for inheritance classes
7. Fewer table fields, no more table Association, and secondary cache support


1. What data query methods does hibernate use?

(1) navigation object graph Query

(2) oId Query

(3) hql

(4) QBC

(5) Local SQL

2. Differences between load () and get ()

 

Load Method:

Java code

Users user = (users) Session. Load (users. Class, userid );

Users user = (users) Session. Load (users. Class, userid );

Get loading method:

Java code

Users user = (users) Session. Get (users. Class, userid );

Users user = (users) Session. Get (users. Class, userid );

 

Differences between the two loading methods:

Difference 1: If there is no userid object in the database. If the get method is used for loading, a null value is returned. If the load method is used for loading, a proxy object is returned. If the following code calls an attribute of the user object (such as user. getPassword () throws an exception: Org. hibernate. objectnotfoundexception;

Difference 2: Load supports delayed loading, while get does not support delayed loading.

That is to say:

Java code

Users user = (users) Session. Load (users. Class, userid );

Users user = (users) Session. Load (users. Class, userid );

This Code does not execute database queries. It only executes database queries when users are used.

And:

Java code

Users user = (users) Session. Get (users. Class, userid );

Users user = (users) Session. Get (users. Class, userid );

Query the database immediately. Therefore, users user = (users) Session. Load (users. Class, userid); no SQL statement is executed.

Note:

Java code

Users user = (users) Session. Load (users. Class, userid );
System. Out. println (user. GETID ());

Users user = (users) Session. Load (users. Class, userid );

System. Out. println (user. GETID ());

The above two statements do not execute database operations. After load, a map object will be stored in the hibernate level-1 cache. The key of the map is the value of userid, but when you use GETID, it takes the map key value in the first-level cache instead of performing database queries. Therefore, no error is reported. No database operations are performed.

 
Describes the execution process of struts2. The struts 2 framework can be roughly divided into three parts: core controller filterdispatcher, business controller action, and enterprise business logic component implemented by users. The core controller filterdispatcher is the basis of the struts 2 Framework and includes the internal control process and processing mechanism. The business controller action and business logic components must be implemented by the user. When developing action and business logic components, you also need to write related configuration files for use by the core controller filterdispatcher. The workflow of struts 2 is simpler than that of struts 1, which is basically the same as that of the webwork framework. Therefore, Struts 2 is an upgraded version of webwork. The basic process is as follows: 1. The client browser sends an HTTP request. 2. According to the Web. xml configuration, this request is received by filterdispatcher. 3. According to struts. xml configuration, find the action class and method to be called, and inject the value to aciton through IOC. 4. Action calls the business logic component to process the business logic. This step contains form verification. 5. After the action is executed, find the corresponding returned result based on the configuration in struts. xml and go to the corresponding page. 6. Return an HTTP Response to the client browser.

This article from the csdn blog, reproduced please indicate the source: http://blog.csdn.net/alli0968/archive/2009/06/01/4231237.aspx

 

 

 

. Struts working mechanism? Why use struts?
Working mechanism:
Struts workflow:
When the web application starts, the initialization actionservlet will be loaded, and the actionservlet will
Read configuration information in the struts-config.xml file and store them to various configuration objects
When the actionservlet receives a customer request, it will execute the following process.
-(1) retrieve the actionmapping instance that matches the user request. If it does not exist, the system returns invalid information about the request path;
-(2) if the actionform instance does not exist, create an actionform object and save the form data submitted by the customer to the actionform object;
-(3) determine whether form verification is required based on the configuration information. If form verification is required, call the validate () method of actionform;
-(4) if the validate () method of actionform returns NULL or an actuiberrors object that does not contain actionmessage is returned, the form verification is successful;
-(5) The actionservlet determines the action to which the request is forwarded based on the actioning information contained in the actionmapping. If the corresponding action instance does not exist, create the instance first, and then call the action's execute () method;
-(6) The execute () method of action returns an actionforward object. The actionservlet is forwarding the client request to the JSP component pointed to by the actionforward object;
-(7) The actionforward object directs to the JSP component to generate a dynamic webpage and return it to the customer;

Why:
The emergence of JSP, Servlet, and JavaBean technologies makes it possible for us to build a powerful enterprise application system. However, systems built with these technologies are very messy. Therefore, we need a rule and a rule to organize these technologies. This is the framework, and Struts came into being.

Struts-based applications are composed of three types of components: controller components, model components, and view components.

8. How is the struts validate framework verified?
Configure the specific error message in the struts configuration file, and then call the validate () method in formbean.

9. Let's talk about the struts design model.
MVC mode: When a web application starts, it loads and initializes actionservler. When a user submits a form, a configured actionform object is created and filled with the corresponding data in the form. actionservler determines whether form verification is required based on the settings configured in the Struts-config.xml file, if you need to call the validate () Verification of actionform, select the action to which the request is sent. If the action does not exist, actionservlet will first create this object and then call the action's execute () method. Execute () obtains data from the actionform object, completes the business logic, returns an actionforward object, and the actionservlet then forwards the customer request to the JSP component specified by the actionforward object, the JSP specified by the actionforward object generates a dynamic webpage and returns it to the customer.

10. Why does spring work?
1. Spring MVC requests all requests to be submitted to dispatcherservlet. It will entrust other modules of the application system to handle the requests in real time.
2. The dispatcherservlet queries one or more handlermapping and finds the Controller that processes the request.
3. Submit the dispatcherservlet request to the target controller.
4. After the controller processes the business logic, a modelandview is returned.
5. The dispathcher queries one or more viewresolver view Resolvers and finds the view object specified by the modelandview object.
6. view objects are rendered and returned to the client.

Why:
{AOP allows developers to create non-behavioral concerns, known as cross-cutting concerns, and insert them into application code. With AOP, public services (such as logs, persistence, and transactions) can be decomposed into aspects and applied to domain objects without increasing the complexity of the Object Model of domain objects.
IOC allows you to create an application environment that can construct objects and then pass their collaboration objects to these objects. As the word inversion indicates, IOC is like the reversed JNDI. Instead of using a bunch of abstract factories, service locators, Singleton, and straight construction, each object is constructed with its collaborative object. Therefore, collaborator is managed by containers ).
Even an AOP framework, spring is also an IOC container. The best thing about spring is that it helps you replace objects. With Spring, you only need to add dependencies (collaboration objects) with the JavaBean attribute and configuration file ). Then, you can easily replace the collaboration object with similar interfaces as needed .}

 


The Spring framework is a layered architecture consisting of seven well-defined modules. The spring module is built on the core container. The core container defines how to create, configure, and manage beans, as shown in figure 1.

Each module (or component) that makes up the Spring framework can exist independently or be implemented together with one or more modules. The functions of each module are as follows:

☆Core container: the Core container provides the basic functions of the Spring framework. The main component of the core container is beanfactory, which is the implementation of the factory mode. Beanfactory uses the control reversal (IOC) mode to separate application configuration and dependency specifications from actual application code.

☆Spring context: Spring context is a configuration file that provides context information to the Spring framework. Spring context includes enterprise services, such as JNDI, EJB, email, internationalization, checksum and scheduling.

☆Spring AOP: Through the configuration management feature, the Spring AOP module directly integrates Aspect-oriented programming functions into the spring framework. Therefore, any objects managed by the Spring framework can easily support AOP. The Spring AOP module provides transaction management services for objects in spring-based applications. By using Spring AOP, You can integrate declarative transaction management into applications without relying on EJB components.

☆Spring Dao: The JDBC Dao abstraction layer provides a meaningful exception hierarchy for managing Exception Handling and error messages thrown by different database vendors. The exception hierarchy simplifies error handling and greatly reduces the number of Exception Code to be written (for example, opening and closing connections ). JDBC-oriented exceptions of spring Dao follow the common Dao exception hierarchy.

☆Spring ORM: The Spring framework inserts several ORM frameworks to provide ORM Object Relational tools, including JDO, hibernate, and ibatis SQL map. All of these comply with the general transactions and Dao exception hierarchies of spring.

☆Spring web module: The Web context module is built on the application context module and provides context for Web-based applications. Therefore, the Spring framework supports integration with Jakarta Struts. The web module also simplifies processing multiple requests and Binding Request Parameters to domain objects.

☆Spring MVC framework: the MVC Framework is a full-featured MVC implementation for Building Web applications. Through the policy interface, the MVC framework becomes highly configurable. MVC supports a large number of view technologies, including JSP, velocity, tiles, itext, and poi.

The functions of the Spring framework can be used on any J2EE server. Most of the functions are also applicable to unmanaged environments. Spring supports reusable services and data access objects that are not bound to a specific J2EE service. There is no doubt that such objects can be reused between different J2EE environments (web or EJB), independent applications, and test environments.

IOC and AOP

The basic concept of the inversion mode (also known as dependency intervention) is to describe how to create objects without creating them. The Code does not directly connect to objects and services, but describes which component needs which service in the configuration file. Containers (IOC containers in the Spring framework) are responsible for connecting these together.

In a typical IOC scenario, the container creates all objects and sets the necessary properties to connect them together to determine the time to call the method. The following table lists an implementation mode of IOC.

 


The IOC container of the Spring framework is implemented by Type 2 and Type 3.


Aspect-Oriented Programming

Aspect-oriented programming (AOP) is a programming technology that allows programmers to modularize the behavior of cross-concern or cross-common division of duties (such as log and transaction management. The core structure of AOP is aspect, which encapsulates the behaviors that affect multiple classes into reusable modules.

AOP and IOC are complementary technologies that use modular methods to solve complex problems in enterprise application development. In a typical object-oriented development method, you may need to place the logging statement in all methods and Java classes to implement the logging function. In the AOP mode, the log service can be modularized in turn and applied to the components that require logs in declarative mode. Of course, the advantage is that the Java class does not need to know the existence of the log service or consider the relevant code. Therefore, application code written with Spring AOP is loosely coupled.

The functions of AOP are fully integrated into the context of Spring transaction management, logs, and other features.

IOC container

The core of spring design is the org. springframework. Beans package, which is designed to be used with the JavaBean Component. This package is usually not directly used by users, but is used by the server as the underlying intermediary for most other functions. The next highest level abstraction is the beanfactory interface, which is an implementation of the factory design pattern and allows the creation and retrieval of objects by name. Beanfactory can also manage relationships between objects.

Beanfactory supports two object models.

□The single-State model provides shared instances for objects with specific names, which can be searched during query. Singleton is the default and most commonly used object model. It is ideal for stateless service objects.

□The prototype model ensures that a separate object is created for each retrieval. When each user needs their own objects, the prototype model is the most suitable.

The concept of Bean Factory is that spring serves as the basis of IOC containers. IOC transfers the responsibility for handling tasks from application code to the framework. As I will demonstrate in the next example, the Spring framework uses the JavaBean attribute and configuration data to indicate the dependencies that must be set.

Beanfactory Interface

Because org. springframework. Beans. Factory. beanfactory is a simple interface, it can be implemented for various underlying storage methods. The most common beanfactory definition is xmlbeanfactory, which loads beans according to the definition in the XML file, as shown in Listing 1.

Listing 1. xmlbeanfactory

Beanfactory factory = new xmlbeanfactory (New fileinputsteam ("mybean. xml "));

The bean defined in the XML file is passively loaded, which means that the bean itself will not be initialized before the bean is needed. To retrieve beans from beanfactory, you only need to call the getbean () method and input the name of the bean to be retrieved, as shown in Listing 2.

Listing 2. getbean ()

Mybean = (mybean) Factory. getbean ("mybean ");

The definition of each bean can be pojo (defined by class name and JavaBean initialization attribute) or factorybean. The factorybean interface adds an indirect level to applications built using the Spring framework.

IOC example

The simplest way to understand control reversal is to look at its practical application. I used an example to summarize Part 1 of the three-part Spring Series, demonstrate how to inject application dependencies through the Spring IoC container (instead of building them in ).

I started with an online credit account use case. To enable a credit account, you must interact with the following services:

☆Credit level evaluation service, which queries users' credit history information.

☆Remote Information Link Service, insert customer information, connect customer information with credit card and bank information for automatic debit (if needed ).

☆Email Service sends an email about the credit card status to the user.

Three Interfaces

For this example, I assume that the service already exists. Ideally, they are integrated in a loosely coupled manner. The following list shows the application interfaces of the three services.

Listing 3. creditratinginterface

Public interface creditratinginterface {
Public Boolean getusercredithistoryinformation (icustomer );
}

The credit level evaluation interface shown in listing 3 provides credit history information. It requires a customer object containing customer information. The implementation of this interface is provided by the creditrating class.

Listing 4. creditlinkinginterface

Public interface creditlinkinginterface {

Public String geturl ();
Public void seturl (string URL );
Public void linkcreditbankaccount () throws exception;

}

The credit Link interface connects the credit history information with the bank information (if needed) and inserts the user's credit card information. The credit Link interface is a remote service and its query is carried out through the geturl () method. The URL is set by the bean configuration mechanism of the Spring framework. I will discuss it later. The implementation of this interface is provided by the creditlinking class.

Listing 5. emailinterface

Public interface emailinterface {

Public void sendemail (icustomer );
Public String getfromemail ();
Public void setfromemail (string fromemail );
Public String GetPassword ();
Public void setpassword (string password );
Public String getsmtphost ();
Public void setsmtphost (string smtphost );
Public String getuserid ();
Public void setuserid (string userid );

Reprinted please indicate the source: http://www.cnblogs.com/javaNewegg/archive/2011/08/28/2156521.html

Working principle and process of the three SSH frameworks)

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.