modeldriven是什么 如何檢驗(yàn)struts2遠(yuǎn)程調(diào)用漏洞

靈霄玉女2022-11-23 19:02:451394

請問Java編程中,Struts2 和 Struts1 比較,有什么優(yōu)勢和區(qū)別呢?struts2給我們提供了什么?學(xué)習(xí)struts2到底學(xué)習(xí)他的什么東西??struts2的modeldriven有什么作用?struts2 中action是什么決定的?struts2 modeldriven攔截器配置中refreshmodelbeforeresult解決什么問題?

本文導(dǎo)航

簡單介紹struts2框架執(zhí)行流程

Apache Struts 2即是之前大家所熟知的WebWork 2。在經(jīng)歷了幾年的各自發(fā)展后,WebWork和Struts社區(qū)決定合二為一,也即是Struts 2

Action 類:

Struts1要求Action類繼承一個抽象基類。Struts1的一個普遍問題是使用抽象類編程而不是接口。

Struts 2 Action類可以實(shí)現(xiàn)一個Action接口,也可實(shí)現(xiàn)其他接口,使可選和定制的服務(wù)成為可能。Struts2提供一個ActionSupport基類去實(shí)現(xiàn) 常用的接口。Action接口不是必須的,任何有execute標(biāo)識的POJO對象都可以用作Struts2的Action對象。

線程模式:

Struts1 Action是單例模式并且必須是線程安全的,因?yàn)閮H有Action的一個實(shí)例來處理所有的請求。單例策略限制了Struts1 Action能作的事,并且要在開發(fā)時特別小心。Action資源必須是線程安全的或同步的。

Struts2 Action對象為每一個請求產(chǎn)生一個實(shí)例,因此沒有線程安全問題。(實(shí)際上,servlet容器給每個請求產(chǎn)生許多可丟棄的對象,并且不會導(dǎo)致性能和垃圾回收問題)

Servlet 依賴:

Struts1 Action 依賴于Servlet API ,因?yàn)楫?dāng)一個Action被調(diào)用時HttpServletRequest 和 HttpServletResponse 被傳遞給execute方法。

Struts 2 Action不依賴于容器,允許Action脫離容器單獨(dú)被測試。如果需要,Struts2 Action仍然可以訪問初始的request和response。但是,其他的元素減少或者消除了直接訪問HttpServetRequest 和 HttpServletResponse的必要性。

可測性:

測試Struts1 Action的一個主要問題是execute方法暴露了servlet API(這使得測試要依賴于容器)。一個第三方擴(kuò)展--Struts TestCase--提供了一套Struts1的模擬對象(來進(jìn)行測試)。

Struts 2 Action可以通過初始化、設(shè)置屬性、調(diào)用方法來測試,“依賴注入”支持也使測試更容易。

捕獲輸入:

Struts1 使用ActionForm對象捕獲輸入。所有的ActionForm必須繼承一個基類。因?yàn)槠渌鸍avaBean不能用作ActionForm,開發(fā)者經(jīng)常創(chuàng)建多余的類捕獲輸入。動態(tài)Bean(DynaBeans)可以作為創(chuàng)建傳統(tǒng)ActionForm的選擇,但是,開發(fā)者可能是在重新描述(創(chuàng)建)已經(jīng)存在的JavaBean(仍然會導(dǎo)致有冗余的javabean)。

Struts 2直接使用Action屬性作為輸入屬性,消除了對第二個輸入對象的需求。輸入屬性可能是有自己(子)屬性的rich對象類型。Action屬性能夠通過web頁面上的taglibs訪問。Struts2也支持ActionForm模式。rich對象類型,包括業(yè)務(wù)對象,能夠用作輸入/輸出對象。這種ModelDriven 特性簡化了taglib對POJO輸入對象的引用。

表達(dá)式語言:

Struts1 整合了JSTL,因此使用JSTL EL。這種EL有基本對象圖遍歷,但是對集合和索引屬性的支持很弱。

Struts2可以使用JSTL,但是也支持一個更強(qiáng)大和靈活的表達(dá)式語言--"Object Graph Notation Language" (OGNL).

綁定值到頁面(view):

Struts 1使用標(biāo)準(zhǔn)JSP機(jī)制把對象綁定到頁面中來訪問。

Struts 2 使用 "ValueStack"技術(shù),使taglib能夠訪問值而不需要把你的頁面(view)和對象綁定起來。ValueStack策略允許通過一系列名稱相同但類型不同的屬性重用頁面(view)。

類型轉(zhuǎn)換:

Struts 1 ActionForm 屬性通常都是String類型。Struts1使用Commons-Beanutils進(jìn)行類型轉(zhuǎn)換。每個類一個轉(zhuǎn)換器,對每一個實(shí)例來說是不可配置的。

Struts2 使用OGNL進(jìn)行類型轉(zhuǎn)換。提供基本和常用對象的轉(zhuǎn)換器。

校驗(yàn):

Struts 1支持在ActionForm的validate方法中手動校驗(yàn),或者通過Commons Validator的擴(kuò)展來校驗(yàn)。同一個類可以有不同的校驗(yàn)內(nèi)容,但不能校驗(yàn)子對象。

Struts2支持通過validate方法和XWork校驗(yàn)框架來進(jìn)行校驗(yàn)。XWork校驗(yàn)框架使用為屬性類類型定義的校驗(yàn)和內(nèi)容校驗(yàn),來支持chain校驗(yàn)子屬性

Action執(zhí)行的控制:

Struts1支持每一個模塊有單獨(dú)的Request Processors(生命周期),但是模塊中的所有Action必須共享相同的生命周期。

Struts2支持通過攔截器堆棧(Interceptor Stacks)為每一個Action創(chuàng)建不同的生命周期。堆棧能夠根據(jù)需要和不同的Action一起使用。

Struts作為MVC 2的Web框架,自推出以來不斷受到開發(fā)者的追捧,得到用廣泛的應(yīng)用。作為最成功的Web框架,Struts自然擁有眾多的優(yōu)點(diǎn):

struts2自學(xué)入門

雖然Struts2號稱是一個全新的框架,但這僅僅是相對Struts 1而言。Struts 2 與Struts 1相比,確實(shí)有很多革命性的改進(jìn),但它并不是新發(fā)布的新框架,而是在另一個赫赫有名的框架:WebWork基礎(chǔ)上發(fā)展起來的。從某種程度上來講,Struts2沒有繼承Struts 1的血統(tǒng),而是繼承WebWork的血統(tǒng)。或者說,WebWork衍生出了Struts2,而不是Struts 1衍生了Struts2。因?yàn)镾truts2是WebWork的升級,而不是一個全新的框架,因此穩(wěn)定性、性能等各方面都有很好的保證:而且吸收了Struts 1和WebWork兩者的優(yōu)勢,因此,是一個非常值得期待的框架?! pache Struts2是一個優(yōu)雅的,可擴(kuò)展的JAVA EE web框架??蚣茉O(shè)計(jì)的目標(biāo)貫穿整個開發(fā)周期,從開發(fā)到發(fā)布,包括維護(hù)的整個過程。  Apache Struts 2即是之前大家所熟知的WebWork 2。在經(jīng)歷了幾年的各自發(fā)展后,WebWork和Struts社區(qū)決定合二為一,也即是Struts 2  Struts 2 英文學(xué)習(xí)網(wǎng)站: http://struts.apache.org/2.0.6/docs/guides.htmlStruts2和Struts1的不同   Action 類:  ◆Struts1要求Action類繼承一個抽象基類。Struts1的一個普遍問題是使用抽象類編程而不是接口?!  鬝truts 2 Action類可以實(shí)現(xiàn)一個Action接口,也可實(shí)現(xiàn)其他接口,使可選和定制的服務(wù)成為可能。Struts2提供一個ActionSupport基類去實(shí)現(xiàn) 常用的接口。Action接口不是必須的,任何有execute標(biāo)識的POJO對象都可以用作Struts2的Action對象。  線程模式:

  ◆Struts1 Action是單例模式并且必須是線程安全的,因?yàn)閮H有Action的一個實(shí)例來處理所有的請求。單例策略限制了Struts1 Action能做的事,并且要在開發(fā)時特別小心。Action資源必須是線程安全的或同步的?!  鬝truts2 Action對象為每一個請求產(chǎn)生一個實(shí)例,因此沒有線程安全問題。(實(shí)際上,servlet容器給每個請求產(chǎn)生許多可丟棄的對象,并且不會導(dǎo)致性能和垃圾回收問題)  Servlet 依賴:

  ◆Struts1 Action 依賴于Servlet API ,因?yàn)楫?dāng)一個Action被調(diào)用時HttpServletRequest 和 HttpServletResponse 被傳遞給execute方法?!  鬝truts 2 Action不依賴于容器,允許Action脫離容器單獨(dú)被測試。如果需要,Struts2 Action仍然可以訪問初始的request和response。但是,其他的元素減少或者消除了直接訪問HttpServetRequest 和 HttpServletResponse的必要性?! 】蓽y性:  ◆測試Struts1 Action的一個主要問題是execute方法暴露了servlet API(這使得測試要依賴于容器)。一個第三方擴(kuò)展--Struts TestCase--提供了一套Struts1的模擬對象(來進(jìn)行測試)。  ◆Struts 2 Action可以通過初始化、設(shè)置屬性、調(diào)用方法來測試,“依賴注入”支持也使測試更容易?! 〔东@輸入:  ◆Struts1 使用ActionForm對象捕獲輸入。所有的ActionForm必須繼承一個基類。因?yàn)槠渌鸍avaBean不能用作ActionForm,開發(fā)者經(jīng)常創(chuàng)建多余的類捕獲輸入。動態(tài)Bean(DynaBeans)可以作為創(chuàng)建傳統(tǒng)ActionForm的選擇,但是,開發(fā)者可能是在重新描述(創(chuàng)建)已經(jīng)存在的JavaBean(仍然會導(dǎo)致有冗余的javabean)?!  ?Struts 2直接使用Action屬性作為輸入屬性,消除了對第二個輸入對象的需求。輸入屬性可能是有自己(子)屬性的rich對象類型。Action屬性能夠通過web頁面上的taglibs訪問。Struts2也支持ActionForm模式。rich對象類型,包括業(yè)務(wù)對象,能夠用作輸入/輸出對象。這種ModelDriven 特性簡化了taglib對POJO輸入對象的引用?! ”磉_(dá)式語言:  ◆Struts1 整合了JSTL,因此使用JSTL EL。這種EL有基本對象圖遍歷,但是對集合和索引屬性的支持很弱。  ◆Struts2可以使用JSTL,但是也支持一個更強(qiáng)大和靈活的表達(dá)式語言--"Object Graph Notation Language" (OGNL).  綁定值到頁面(view):  ◆ Struts 1使用標(biāo)準(zhǔn)JSP機(jī)制把對象綁定到頁面中來訪問?!  鬝truts 2 使用 "ValueStack"技術(shù),使taglib能夠訪問值而不需要把你的頁面(view)和對象綁定起來。ValueStack策略允許通過一系列名稱相同但類型不同的屬性重用頁面(view)?! ☆愋娃D(zhuǎn)換:  ◆Struts 1 ActionForm 屬性通常都是String類型。Struts1使用Commons-Beanutils進(jìn)行類型轉(zhuǎn)換。每個類一個轉(zhuǎn)換器,對每一個實(shí)例來說是不可配置的。  ◆Struts2 使用OGNL進(jìn)行類型轉(zhuǎn)換。提供基本和常用對象的轉(zhuǎn)換器?! ⌒r?yàn):  ◆Struts 1支持在ActionForm的validate方法中手動校驗(yàn),或者通過Commons Validator的擴(kuò)展來校驗(yàn)。同一個類可以有不同的校驗(yàn)內(nèi)容,但不能校驗(yàn)子對象?!  鬝truts2支持通過validate方法和XWork校驗(yàn)框架來進(jìn)行校驗(yàn)。XWork校驗(yàn)框架使用為屬性類類型定義的校驗(yàn)和內(nèi)容校驗(yàn),來支持chain校驗(yàn)子屬性  Action執(zhí)行的控制:  ◆Struts1支持每一個模塊有單獨(dú)的Request Processors(生命周期),但是模塊中的所有Action必須共享相同的生命周期。  ◆Struts2支持通過攔截器堆棧(Interceptor Stacks)為每一個Action創(chuàng)建不同的生命周期。堆棧能夠根據(jù)需要和不同的Action一起使用。

struts2完整配置

您好,實(shí)現(xiàn)了ModelDriven就必須實(shí)現(xiàn)getModel這個方法,該方法返回的是你的ModelDrivern泛型中設(shè)定的實(shí)體類。其實(shí)是為了實(shí)現(xiàn)代碼的重用,不要再定義一次你在數(shù)據(jù)訪問層定義的屬性了,直接用那個類就行了。不過有時候也不是很需要這個東西,比如只有一兩個表單域的時候。

struts2請求步驟

  struts2 中action是通過struts.xml配置文件來實(shí)現(xiàn)的。

Struts2中Action接收參數(shù)的方法主要有以下三種:

1.使用Action的屬性接收參數(shù):

a.定義:在Action類中定義屬性,創(chuàng)建get和set方法;

b.接收:通過屬性接收參數(shù),如:userName;

c.發(fā)送:使用屬性名傳遞參數(shù),如:user1!add?userName=Magci;

2.使用DomainModel接收參數(shù):

a.定義:定義Model類,在Action中定義Model類的對象(不需要new),創(chuàng)建該對象的get和set方法;

b.接收:通過對象的屬性接收參數(shù),如:user.getUserName();

c.發(fā)送:使用對象的屬性傳遞參數(shù),如:user2!add?user.userName=MGC;

3.使用ModelDriven接收參數(shù):

a.定義:Action實(shí)現(xiàn)ModelDriven泛型接口,定義Model類的對象(必須new),通過getModel方法返回該對象;

b.接收:通過對象的屬性接收參數(shù),如:user.getUserName();

c.發(fā)送:直接使用屬性名傳遞參數(shù),如:user2!add?userName=MGC

如何檢驗(yàn)struts2遠(yuǎn)程調(diào)用漏洞

  所謂ModelDriven,意思是直接把實(shí)體類當(dāng)成頁面數(shù)據(jù)的收集對象。比如,有實(shí)體類User如下:

  package cn.com.leadfar.struts2.actions;

  public class User {

  private int id;

  private String username;

  private String password;

  private int age;

  private String address;

  public String getUsername() {

  return username;

  }

  public void setUsername(String username) {

  this.username = username;

  }

  public String getPassword() {

  return password;

  }

  public void setPassword(String password) {

  this.password = password;

  }

  public int getAge() {

  return age;

  }

  public void setAge(int age) {

  this.age = age;

  }

  public String getAddress() {

  return address;

  }

  public void setAddress(String address) {

  this.address = address;

  }

  public int getId() {

  return id;

  }

  public void setId(int id) {

  this.id = id;

  }

  }

  

  假如要寫一個Action,用來添加User。

  第一種做法是直接在Action中定義所有需要的屬性,然后在JSP中直接用屬性名稱來提交數(shù)據(jù):

  UserAction:

  public class UserAction {

  private int id;

  private String username;

  private String password;

  private int age;

  private String address;

  public String add(){

  User user = new User();

  user.setId(id);

  user.setUsername(username);

  user.setPassword(password);

  user.setAge(age);

  user.setAddress(address);

  new UserManager().addUser(user);

  return "success";

  }

  public int getId() {

  return id;

  }

  public void setId(int id) {

  this.id = id;

  }

  public String getUsername() {

  return username;

  }

  public void setUsername(String username) {

  this.username = username;

  }

  public String getPassword() {

  return password;

  }

  public void setPassword(String password) {

  this.password = password;

  }

  public int getAge() {

  return age;

  }

  public void setAge(int age) {

  this.age = age;

  }

  public String getAddress() {

  return address;

  }

  public void setAddress(String address) {

  this.address = address;

  }

  }

  

  add_input.jsp:

  <form action="test/user.action" method="post">

  <input type="hidden" name="method:add">

  username:<input type="text" name="username"> <br/>

  password:<input type="text" name="password"> <br/>

  age:<input type="text" name="age"> <br/>

  address:<input type="text" name="address"> <br/>

  <input type="submit" name="submit" value="添加用戶">

  </form> <br/>

  

  上述做法不好之處是:如果實(shí)體類的屬性非常多,那么Action中也要定義相同的屬性。

  第二種做法是將User對象定義到UserAction中,然后在JSP中通過user屬性來給user賦值:

  UserAction:

  public class UserAction {

  private User user;

  public String add(){

  new UserManager().addUser(user);

  return "success";

  }

  public User getUser() {

  return user;

  }

  public void setUser(User user) {

  this.user = user;

  }

  }

  

  add_input.jsp:

  <form action="test/user.action" method="post">

  <input type="hidden" name="method:add">

  username:<input type="text" name="user.username"> <br/>

  password:<input type="text" name="user.password"> <br/>

  age:<input type="text" name="user.age"> <br/>

  address:<input type="text" name="user.address"> <br/>

  <input type="submit" name="submit" value="添加用戶">

  </form> <br/>

  

  這種做法不好的地方是:JSP頁面上表單域中的命名變得太長

  第三種做法是利用ModelDriven機(jī)制,讓UserAction實(shí)現(xiàn)一個ModelDriven接口,同時實(shí)現(xiàn)接口中的方法:getModel()。如下所示:

  public class UserAction implements ModelDriven{

  private User user;

  @Override

  public Object getModel() {

  if(user == null){

  user = new User();

  }

  return user;

  }

  public String add(){

  new UserManager().addUser(user);

  return "success";

  }

  public User getUser() {

  return user;

  }

  public void setUser(User user) {

  this.user = user;

  }

  }

  

  JSP的代碼如下:

  <form action="test/user.action" method="post">

  <input type="hidden" name="method:add">

  username:<input type="text" name="username"> <br/>

  password:<input type="text" name="password"> <br/>

  age:<input type="text" name="age"> <br/>

  <input type="submit" name="submit" value="添加用戶">

  </form> <br/>

  

  可見,第三種做法是比較好的,Action和JSP寫起來都比較簡單。

  2.ModelDriven背后的機(jī)制?

  ModelDriven背后的機(jī)制就是ValueStack。界面通過:username/age/address這樣的名稱,就能夠被直接賦值給user對象,這證明user對象正是ValueStack中的一個root對象!

  那么,為什么user對象會在ValueStack中呢?它是什么時候被壓入ValueStack的呢?答案是:ModelDrivenInterceptor(關(guān)于Interceptor的概念,請參考后續(xù)章節(jié)的說明)。ModelDrivenInterceptor是缺省的攔截器鏈的一部分,當(dāng)一個請求經(jīng)過ModelDrivenInterceptor的時候,在這個攔截器中,會判斷當(dāng)前要調(diào)用的Action對象是否實(shí)現(xiàn)了ModelDriven接口,如果實(shí)現(xiàn)了這個接口,則調(diào)用getModel()方法,并把返回值(本例是返回user對象)壓入ValueStack。

  請看ModelDrivenInterceptor的代碼:

  public class ModelDrivenInterceptor extends AbstractInterceptor {

  protected boolean refreshModelBeforeResult = false;

  public void setRefreshModelBeforeResult(boolean val) {

  this.refreshModelBeforeResult = val;

  }

  @Override

  public String intercept(ActionInvocation invocation) throws Exception {

  Object action = invocation.getAction();

  if (action instanceof ModelDriven) {

  ModelDriven modelDriven = (ModelDriven) action;

  ValueStack stack = invocation.getStack();

  Object model = modelDriven.getModel();

  if (model != null) {

  stack.push(model);

  }

  if (refreshModelBeforeResult) {

  invocation.addPreResultListener(new RefreshModelBeforeResult(modelDriven, model));

  }

  }

  return invocation.invoke();

  }

  

  從ModelDrivenInterceptor中,即可以看到model對象被壓入ValueStack中!

  其中的refreshModelBeforeResult是為了接下來描述的一個問題而提供的解決方法。

理解常見的陷阱及解決辦法

  假設(shè)我們要更新一個實(shí)體對象,那么第一步首先是打開更新界面,請看下述模擬打開更新界面的代碼:

  public class UserAction implements ModelDriven{

  private User user;

  @Override

  public Object getModel() {

  if(user == null){

  user = new User();

  //user.setUsername("這是原來的User對象");

  }

  return user;

  }

  public String updateInput(){

  //根據(jù)ID,查詢數(shù)據(jù)庫,得到User對象

  user = new UserManager().findUserById(user.getId());

  return "update_input";

  }

  

  上述代碼中,new UserManager().findUserById(user.getId());這一行,將從數(shù)據(jù)庫中查詢相應(yīng)的記錄,同時轉(zhuǎn)換為User對象返回。而return “update_input”;將轉(zhuǎn)向更新顯示頁面。

  更新頁面如下:

  <form action="test/user.action" method="post">

  <input type="hidden" name="method:update">

  id:<input type="text" name="id" value="<s:property value="id"/>"> <br/>

  username:<input type="text" name="username" value="<s:property value="username"/>"><br/>

  password:<input type="text" name="password" value="<s:property value="password"/>"><br/>

  age:<input type="text" name="age" value="<s:property value="age"/>"> <br/>

  address:<input type="text" name="address" value="<s:property value="address"/>"><br/>

  <input type="submit" name="submit" value="更新用戶">

  </form> <br/>

  

  上述代碼運(yùn)行起來之后,你在更新界面上將看不到數(shù)據(jù)(id屬性有值,其它屬性無顯示)。關(guān)鍵的原因是在執(zhí)行到updateInput之前,user對象(在getMode()方法中創(chuàng)建的對象)被壓到ValueStack中,這時候,UserAction和ValueStack都指向同一個user對象;但緊接著,UserAction中的user被一個新的user對象覆蓋,這時候,UserAction和ValueStack不再指向同一個user對象!ValueStack中是舊的user對象,而UserAction中是新的user對象!我們在JSP中,直接通過username/address等直接訪問,當(dāng)然是要訪問ValueStack中的舊user對象,所以它們的屬性都是空的(id屬性除外)!

  理解上述問題很重要,當(dāng)你理解了問題,那么問題的解決方法就可以有很多了:

  比如,你可以把新對象的屬性拷貝到舊對象上;比如,你可以先把舊對象從ValueStack中移除,然后再把新對象壓入ValueStack等……

  在最新的struts2版本中,ModelDrivenInterceptor提供了一個配置參數(shù):refreshModelBeforeResult,只要將它定義為true,上述問題就被解決了!struts2的解決方案就是:先把舊的model對象從ValueStack中移除,然后再把新的model對象壓入ValueStack!

掃描二維碼推送至手機(jī)訪問。

版權(quán)聲明:本文由尚恩教育網(wǎng)發(fā)布,如需轉(zhuǎn)載請注明出處。

本文鏈接:http://www.lmix.com.cn/view/68704.html

標(biāo)簽: 生活

“modeldriven是什么 如何檢驗(yàn)struts2遠(yuǎn)程調(diào)用漏洞” 的相關(guān)文章

河北青年管理干部學(xué)院 河北青年管理干部學(xué)院2022年放假

河北青年管理干部學(xué)院 河北青年管理干部學(xué)院2022年放假

河北青年管理干部學(xué)院怎樣?急?河北青年管理干部學(xué)院的女生宿舍是什么樣的啊,幾人間吶?河北青年干部管理學(xué)院怎么樣?河北青年管理干部學(xué)院分?jǐn)?shù)線2021,河北青年管理干部學(xué)院優(yōu)秀團(tuán)員一個班幾個名額,河北青年管理干部學(xué)院2021單招分?jǐn)?shù)線什么時候下來?本文導(dǎo)航河北青年管理干部學(xué)院內(nèi)地圖河北青年管理干部學(xué)院2...

洗手間指示牌 衛(wèi)生間標(biāo)識標(biāo)牌圖解

洗手間指示牌 衛(wèi)生間標(biāo)識標(biāo)牌圖解

w和m哪個代表男廁所,哪個代表女廁所,洗手間標(biāo)識牌尺寸一般是多少?衛(wèi)生間指示牌尺寸一般是多少?衛(wèi)生間指示牌尺寸一般是多少?廁所標(biāo)識是什么?衛(wèi)生間標(biāo)識是什么?本文導(dǎo)航女廁所面積比男廁大嗎衛(wèi)生間標(biāo)識標(biāo)牌圖解衛(wèi)生間標(biāo)牌尺寸對照表標(biāo)準(zhǔn)衛(wèi)生間標(biāo)識牌廁所的標(biāo)識圖片衛(wèi)生間標(biāo)識尺寸對照表女廁所面積比男廁大嗎w是wo...

太原市第五中學(xué) 2021太原五中預(yù)估錄取分?jǐn)?shù)線

太原市第五中學(xué) 2021太原五中預(yù)估錄取分?jǐn)?shù)線

太原五中是山西省重點(diǎn)中學(xué)嗎?如何看待太原五中近年學(xué)校整體相對實(shí)力退步現(xiàn)象?太原五中小升初錄取分?jǐn)?shù)線,太原五中官網(wǎng)進(jìn)不去,2022年太原五中多少分能上?太原2021年初中升學(xué)率排名。本文導(dǎo)航太原五中和六中哪個好太原五中高中升學(xué)率太原五中龍城校區(qū)招生分?jǐn)?shù)線太原五中高中怎么報(bào)名2021太原五中預(yù)估錄取分?jǐn)?shù)...

防汛應(yīng)急演練 防汛應(yīng)急演練過程中的注意事項(xiàng)

防汛應(yīng)急演練 防汛應(yīng)急演練過程中的注意事項(xiàng)

防汛應(yīng)急預(yù)案有哪些,防汛演練的目的,如何開展防臺防汛演練?如何?進(jìn)行防汛應(yīng)急預(yù)案?演練工作?防汛應(yīng)急演練接到應(yīng)急啟動信息警戒組當(dāng)開展什么工作?防洪防汛的應(yīng)急救援措施。本文導(dǎo)航防汛應(yīng)急措施有哪些防汛減災(zāi)的演練目的防汛應(yīng)急演練過程中的注意事項(xiàng)防汛工作應(yīng)急處置預(yù)案防汛應(yīng)急組織機(jī)構(gòu)圖防洪防汛四級應(yīng)急預(yù)案防汛...

陽泉工業(yè)學(xué)校 陽泉市職高學(xué)校有哪些

陽泉工業(yè)學(xué)校的專業(yè),關(guān)于山西省陽泉市“實(shí)驗(yàn)中學(xué)”、“陽泉六中”、“工業(yè)學(xué)校,陽泉工業(yè)學(xué)校和陽泉古城中學(xué)哪個比較好呢?陽泉市工業(yè)學(xué)校好不好?學(xué)什么專業(yè)好?陽泉市工業(yè)學(xué)校怎么樣?陽泉有幾個技校 說清楚 別說那個好 就說有幾個。本文導(dǎo)航陽泉工業(yè)學(xué)校好不好陽泉市六中學(xué)校在哪陽泉市所有職高學(xué)校排行陽泉市職業(yè)高...

初四拜年片 初四可以發(fā)短信拜年嗎

初四拜年片 初四可以發(fā)短信拜年嗎

賀歲片一說從哪里來?初四能不能去拜年,新年初四能拜年嗎?初四為什么不能拜年嗎?初四拜年祝福語。本文導(dǎo)航今年賀歲片哪個好初四拜年的人多嗎初四可以發(fā)短信拜年嗎初四為啥不拜年正月初二拜年簡短祝福語今年賀歲片哪個好  赤壁“賀歲片”這一說法是由素有“東方好萊塢”之稱的香港傳入內(nèi)地的。所謂賀歲片,是指在元旦、...

發(fā)表評論

訪客

◎歡迎參與討論,請?jiān)谶@里發(fā)表您的看法和觀點(diǎn)。