[英]ADF integration with EBS
我在 Oracle adf 中開發了一個應用程序,現在我想將此應用程序與電子商務套件集成。 所以請讓我知道有人知道這個過程嗎?
我得到了如何將 ADF 頁面與 EBS 以及會話管理集成的解決方案。
下面的鏈接對我很有用。
或執行以下步驟以獲得更多描述。
步驟 01:創建 Java 類。 Java 類:ConnectionProvide、EBizUti、EBSWrapperFilter、Java Bean:UserInfo
1.ConnectionProvider.java
package com.oracle.view;
import java.sql.Connection;
import java.sql.SQLException;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.sql.DataSource;
public class ConnectionProvider {
private static DataSource ebsDS = null;
static {
try {
Context ctx = new InitialContext();
ebsDS = (DataSource) ctx.lookup("jdbc/TEST32");
// your datasource jndi name as defined during configuration
if (ctx != null)
ctx.close();
} catch (Exception e) {
throw new RuntimeException(e);
// means jndi setup is not correct or doesn't exist
}
}
private ConnectionProvider() {
super();
}
public static Connection getConnection() throws SQLException {
if (ebsDS == null)
throw new IllegalStateException(
"AppsDatasource is not properly initialized or available");
return ebsDS.getConnection();
}
}
PS:在EBS環境jdbc模式下獲取數據庫連接,可以進入weblogic的Services->Data Sources視圖,如:EBSDataSource JNDI:jdbc/TEST32,可以學習部署到那一台主機:oacore_cluster
2.EBizUtil.java
package com.oracle.view;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger;
import oracle.apps.fnd.ext.common.EBiz;
public class EBizUtil {
public EBizUtil() {
super();
}
private static final Logger logger = Logger.getLogger(EBizUtil.class.getName());
private static EBiz INSTANCE = null;
static {
Connection connection = null;
try {
connection = ConnectionProvider.getConnection();
// DO NOT hard code applServerID for a real application
// Get applServerID as CONTEXT-PARAM from web.xml or elsewhere
INSTANCE = new EBiz(connection, "F1CB87199593E5F4E0431F030A0AD0AB31310251131793525291714692481335");
} catch (SQLException e) {
logger.log(Level.SEVERE, "SQLException while creating EBiz instance", e);
throw new RuntimeException(e);
} catch (Exception e) {
logger.log(Level.SEVERE, "Exception while creating EBiz instance", e);
throw new RuntimeException(e);
} finally {
if (connection != null) {
try {
connection.close();
} catch (SQLException e) {
throw new RuntimeException(e);
}
}
}
}
public static EBiz getEBizInstance() {
return INSTANCE;
}
}
PS:APPL_SERVER_ID可以在$INST_TOP/appl/fnd/12.0.0/secure/TEST32.dbc下獲取EBS APP Server路徑Server ID:APPL_SERVER_ID = F1CB87199593E5F4E0431F030A0AD0AB313107925134131315231341
3.EBSWrapperFilter.java
package com.oracle.view;
import java.io.IOException;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import oracle.apps.fnd.ext.common.AppsRequestWrapper;
import oracle.apps.fnd.ext.common.AppsRequestWrapper.WrapperException;
public class EBSWrapperFilter implements Filter {
public EBSWrapperFilter() {
super();
}
private static final Logger logger = Logger.getLogger(EBSWrapperFilter.class.getName());
public void init(FilterConfig filterConfig) {
logger.info("Filter initialized ");
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException,ServletException {
AppsRequestWrapper wrapper = null;
logger.info("-current URI =" + ((HttpServletRequest)request).getRequestURI());
try {
wrapper = new AppsRequestWrapper((HttpServletRequest)request, (HttpServletResponse)response, ConnectionProvider.getConnection(), EBizUtil.getEBizInstance());
} catch (WrapperException e2) {
logger.log(Level.SEVERE, "WrapperException error encountered ", e2);
throw new ServletException(e2);
} catch (SQLException e2) {
logger.log(Level.SEVERE, "SQLException error encountered ", e2);
throw new ServletException(e2);
}
try {
logger.info("Created AppsRequestWrapper object." + " Continuing the filter chain.");
chain.doFilter(wrapper, response);
logger.info("- the filter chain ends");
} finally {
//AppsRequestWrapper caches a connection internally.
//AppsRequestWrapper.getConnection()--returns this connection this connection can be used in doGet()/doPost() service layer
//whenever our application requires a connection in order to service the current request.
//When AppsRequestWrapper instance is in use, this connection should not be closed by other code.
//At this point, we are done using AppsRequestWrapper instance so, as good practice, we are going to close (release) this connection now.
if (wrapper != null) {
try {
logger.info("- releasing the connection attached to the" + " current AppsRequestWrapper instance ");
wrapper.getConnection().close();
} catch (SQLException e3) {
logger.log(Level.WARNING, "SQLException error while closing connection--", e3);
throw new ServletException(e3);
}
}
wrapper = null;
}
}
public void destroy() {
logger.info("Filter destroyed ");
}
}
4.用戶信息.java
package com.oracle.bean;
import java.util.Map;
import javax.faces.context.FacesContext;
import javax.faces.event.PhaseEvent;
import oracle.apps.fnd.ext.common.AppsRequestWrapper;
import oracle.apps.fnd.ext.common.Session;
public class UserInfo {
private String user;
private String userInfo;
public UserInfo() {
super();
}
public void setUser(String user) {
this.user = user;
}
public String getUser() {
return user;
}
public void beforePhase(PhaseEvent phaseEvent) {
// Add event code here...
AppsRequestWrapper wrappedRequest =
(AppsRequestWrapper)FacesContext.getCurrentInstance().getExternalContext().getRequest();
Session session = wrappedRequest.getAppsSession();
setUser(session.getUserName());
Map columns = session.getInfo();
StringBuffer temp = new StringBuffer();
temp.append("<table>");
for (Object key : columns.keySet()) {
temp.append("<tr>");
temp.append("<td>");
temp.append(key);
temp.append("</td>");
temp.append("<td>");
temp.append(columns.get(key));
temp.append("</td>");
temp.append("</tr>");
}
temp.append("</table>");
setUserInfo(temp.toString());
}
public void setUserInfo(String userInfo) {
this.userInfo = userInfo;
}
public String getUserInfo() {
return userInfo;
}
}
步驟 02:在 adfc-config.xml 中創建視圖:userInfo.jspx 並設置 Managed Beans
Layout: PageGroupLayout: layout = vertical
OutPutText: value = "Hello # {pageFlowScope.userInfoBean.user} !!"
InlineStyle = "font-size: medium; color: Red;"
Separator
OutPutText: value = "# User Info: <br> # {pageFlowScope.userInfoBean.userInfo}"
Escape = "false" inlineStyle = "font-size: medium;"
Oracle EBS 上的設置:
步驟 01:設置功能:菜單:職責:功能 WEI_ADFLAB_USERINFO Properties-Type External ADF Application WebHTML-HTML Call GWY.jsp?targetPage=faces/userInfo
步驟 02:職責:功能管理員設置核心服務 → 配置文件 → 代碼:FND_EXTERNAL_ADF_URL → Go b. 然后單擊外部 ADF 應用程序 URL 並按定義配置文件值
一種。 單擊定義概要文件值 → 職責 b. 選擇責任和價值 c. 值:weblogic路徑下的guest程序,如: http://lnxap104:7214/LAB_EBS-ViewController-context-root/ d. 新聞更新
取決於您要創建的集成類型 - 這里有一些基礎知識:https ://blogs.oracle.com/jruiz/entry/adf_and_oracle_e_business2
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.