Php 让QuercusView与SpringMVC协同工作
我正在尝试实现SpringMVC+Quercus,如中所述 因此,我将Spring设置为:Php 让QuercusView与SpringMVC协同工作,php,spring-mvc,quercus,Php,Spring Mvc,Quercus,我正在尝试实现SpringMVC+Quercus,如中所述 因此,我将Spring设置为: @Controller @RequestMapping("account/*") public class AccountController { public AccountController() {} @RequestMapping("signup") public String signupTestHandler() { return "signup";
@Controller
@RequestMapping("account/*")
public class AccountController {
public AccountController() {}
@RequestMapping("signup")
public String signupTestHandler() {
return "signup";
}
}
package com.caucho.spring.quercus;
import java.io.*;
import java.util.*;
import java.util.logging.*;
import javax.servlet.*;
import javax.servlet.http.*;
import com.caucho.quercus.*;
import com.caucho.quercus.env.*;
import com.caucho.quercus.module.*;
import com.caucho.quercus.page.*;
import com.caucho.util.L10N;
import com.caucho.vfs.*;
import org.springframework.web.servlet.*;
import org.springframework.web.servlet.view.*;
public class QuercusView
extends AbstractUrlBasedView
{
private static final L10N L = new L10N(QuercusView.class);
private static final Logger log
= Logger.getLogger(QuercusView.class.getName());
protected QuercusContext _quercus;
protected ServletContext _servletContext;
public QuercusView()
{
super();
}
protected void initServletContext(ServletContext servletContext)
{
_servletContext = servletContext;
checkServletAPIVersion();
getQuercus().setPwd(new FilePath(_servletContext.getRealPath("/")));
getQuercus().init();
}
protected void checkServletAPIVersion()
{
int major = _servletContext.getMajorVersion();
int minor = _servletContext.getMinorVersion();
if (major < 2 || major == 2 && minor < 4)
throw new QuercusRuntimeException(L.l("Quercus requires Servlet API 2.4+."));
}
protected void renderMergedOutputModel(Map model,
HttpServletRequest request,
HttpServletResponse response)
throws Exception
{
Env env = null;
WriteStream ws = null;
try {
Path path = getPath(request);
QuercusPage page;
try {
page = getQuercus().parse(path);
}
catch (FileNotFoundException ex) {
// php/2001
log.log(Level.FINER, ex.toString(), ex);
response.sendError(HttpServletResponse.SC_NOT_FOUND);
return;
}
StreamImpl out;
try {
out = new VfsStream(null, response.getOutputStream());
}
catch (IllegalStateException e) {
WriterStreamImpl writer = new WriterStreamImpl();
writer.setWriter(response.getWriter());
out = writer;
}
ws = new WriteStream(out);
ws.setNewlineString("\n");
QuercusContext quercus = getQuercus();
quercus.setServletContext(_servletContext);
env = quercus.createEnv(page, ws, request, response);
// retro... thanks, Spring
for (Object entryObj : model.entrySet()) {
Map.Entry entry = (Map.Entry) entryObj;
env.setScriptGlobal((String) entry.getKey(), entry.getValue());
}
try {
env.start();
env.setScriptGlobal("request", request);
env.setScriptGlobal("response", response);
env.setScriptGlobal("servletContext", _servletContext);
StringValue prepend
= quercus.getIniValue("auto_prepend_file").toStringValue(env);
if (prepend.length() > 0) {
Path prependPath = env.lookup(prepend);
if (prependPath == null)
env.error(L.l("auto_prepend_file '{0}' not found.", prepend));
else {
QuercusPage prependPage = getQuercus().parse(prependPath);
prependPage.executeTop(env);
}
}
env.executeTop();
StringValue append
= quercus.getIniValue("auto_append_file").toStringValue(env);
if (append.length() > 0) {
Path appendPath = env.lookup(append);
if (appendPath == null)
env.error(L.l("auto_append_file '{0}' not found.", append));
else {
QuercusPage appendPage = getQuercus().parse(appendPath);
appendPage.executeTop(env);
}
}
// return;
}
catch (QuercusExitException e) {
throw e;
}
catch (QuercusErrorException e) {
throw e;
}
catch (QuercusLineRuntimeException e) {
log.log(Level.FINE, e.toString(), e);
// return;
}
catch (QuercusValueException e) {
log.log(Level.FINE, e.toString(), e);
ws.println(e.toString());
// return;
}
catch (Throwable e) {
if (response.isCommitted())
e.printStackTrace(ws.getPrintWriter());
ws = null;
throw e;
}
finally {
if (env != null)
env.close();
// don't want a flush for a thrown exception
if (ws != null)
ws.close();
}
}
catch (QuercusDieException e) {
// normal exit
log.log(Level.FINE, e.toString(), e);
}
catch (QuercusExitException e) {
// normal exit
log.log(Level.FINER, e.toString(), e);
}
catch (QuercusErrorException e) {
// error exit
log.log(Level.FINE, e.toString(), e);
}
catch (RuntimeException e) {
throw e;
}
catch (Throwable e) {
throw new ServletException(e);
}
}
Path getPath(HttpServletRequest req)
{
String scriptPath = getUrl();
String pathInfo = QuercusRequestAdapter.getPagePathInfo(req);
Path pwd = new FilePath(System.getProperty("user.dir"));
Path path = pwd.lookup(req.getRealPath(scriptPath));
if (path.isFile())
return path;
// XXX: include
String fullPath;
if (pathInfo != null)
fullPath = scriptPath + pathInfo;
else
fullPath = scriptPath;
return pwd.lookup(req.getRealPath(fullPath));
}
/**
* Returns the Quercus instance.
*/
protected QuercusContext getQuercus()
{
synchronized (this) {
if (_quercus == null)
_quercus = new QuercusContext();
}
return _quercus;
}
/**
* Gets the script manager.
*/
public void destroy()
{
_quercus.close();
}
}
web.xml
QuercusView如下所示:
@Controller
@RequestMapping("account/*")
public class AccountController {
public AccountController() {}
@RequestMapping("signup")
public String signupTestHandler() {
return "signup";
}
}
package com.caucho.spring.quercus;
import java.io.*;
import java.util.*;
import java.util.logging.*;
import javax.servlet.*;
import javax.servlet.http.*;
import com.caucho.quercus.*;
import com.caucho.quercus.env.*;
import com.caucho.quercus.module.*;
import com.caucho.quercus.page.*;
import com.caucho.util.L10N;
import com.caucho.vfs.*;
import org.springframework.web.servlet.*;
import org.springframework.web.servlet.view.*;
public class QuercusView
extends AbstractUrlBasedView
{
private static final L10N L = new L10N(QuercusView.class);
private static final Logger log
= Logger.getLogger(QuercusView.class.getName());
protected QuercusContext _quercus;
protected ServletContext _servletContext;
public QuercusView()
{
super();
}
protected void initServletContext(ServletContext servletContext)
{
_servletContext = servletContext;
checkServletAPIVersion();
getQuercus().setPwd(new FilePath(_servletContext.getRealPath("/")));
getQuercus().init();
}
protected void checkServletAPIVersion()
{
int major = _servletContext.getMajorVersion();
int minor = _servletContext.getMinorVersion();
if (major < 2 || major == 2 && minor < 4)
throw new QuercusRuntimeException(L.l("Quercus requires Servlet API 2.4+."));
}
protected void renderMergedOutputModel(Map model,
HttpServletRequest request,
HttpServletResponse response)
throws Exception
{
Env env = null;
WriteStream ws = null;
try {
Path path = getPath(request);
QuercusPage page;
try {
page = getQuercus().parse(path);
}
catch (FileNotFoundException ex) {
// php/2001
log.log(Level.FINER, ex.toString(), ex);
response.sendError(HttpServletResponse.SC_NOT_FOUND);
return;
}
StreamImpl out;
try {
out = new VfsStream(null, response.getOutputStream());
}
catch (IllegalStateException e) {
WriterStreamImpl writer = new WriterStreamImpl();
writer.setWriter(response.getWriter());
out = writer;
}
ws = new WriteStream(out);
ws.setNewlineString("\n");
QuercusContext quercus = getQuercus();
quercus.setServletContext(_servletContext);
env = quercus.createEnv(page, ws, request, response);
// retro... thanks, Spring
for (Object entryObj : model.entrySet()) {
Map.Entry entry = (Map.Entry) entryObj;
env.setScriptGlobal((String) entry.getKey(), entry.getValue());
}
try {
env.start();
env.setScriptGlobal("request", request);
env.setScriptGlobal("response", response);
env.setScriptGlobal("servletContext", _servletContext);
StringValue prepend
= quercus.getIniValue("auto_prepend_file").toStringValue(env);
if (prepend.length() > 0) {
Path prependPath = env.lookup(prepend);
if (prependPath == null)
env.error(L.l("auto_prepend_file '{0}' not found.", prepend));
else {
QuercusPage prependPage = getQuercus().parse(prependPath);
prependPage.executeTop(env);
}
}
env.executeTop();
StringValue append
= quercus.getIniValue("auto_append_file").toStringValue(env);
if (append.length() > 0) {
Path appendPath = env.lookup(append);
if (appendPath == null)
env.error(L.l("auto_append_file '{0}' not found.", append));
else {
QuercusPage appendPage = getQuercus().parse(appendPath);
appendPage.executeTop(env);
}
}
// return;
}
catch (QuercusExitException e) {
throw e;
}
catch (QuercusErrorException e) {
throw e;
}
catch (QuercusLineRuntimeException e) {
log.log(Level.FINE, e.toString(), e);
// return;
}
catch (QuercusValueException e) {
log.log(Level.FINE, e.toString(), e);
ws.println(e.toString());
// return;
}
catch (Throwable e) {
if (response.isCommitted())
e.printStackTrace(ws.getPrintWriter());
ws = null;
throw e;
}
finally {
if (env != null)
env.close();
// don't want a flush for a thrown exception
if (ws != null)
ws.close();
}
}
catch (QuercusDieException e) {
// normal exit
log.log(Level.FINE, e.toString(), e);
}
catch (QuercusExitException e) {
// normal exit
log.log(Level.FINER, e.toString(), e);
}
catch (QuercusErrorException e) {
// error exit
log.log(Level.FINE, e.toString(), e);
}
catch (RuntimeException e) {
throw e;
}
catch (Throwable e) {
throw new ServletException(e);
}
}
Path getPath(HttpServletRequest req)
{
String scriptPath = getUrl();
String pathInfo = QuercusRequestAdapter.getPagePathInfo(req);
Path pwd = new FilePath(System.getProperty("user.dir"));
Path path = pwd.lookup(req.getRealPath(scriptPath));
if (path.isFile())
return path;
// XXX: include
String fullPath;
if (pathInfo != null)
fullPath = scriptPath + pathInfo;
else
fullPath = scriptPath;
return pwd.lookup(req.getRealPath(fullPath));
}
/**
* Returns the Quercus instance.
*/
protected QuercusContext getQuercus()
{
synchronized (this) {
if (_quercus == null)
_quercus = new QuercusContext();
}
return _quercus;
}
/**
* Gets the script manager.
*/
public void destroy()
{
_quercus.close();
}
}
我使用Tomcat+openejb+Spring3作为EJB容器
谢谢你的帮助
拜托,我不太了解SpringMVC和Quercus的内部工作原理,但我希望有人能帮助我解决这个问题
谢谢你的帮助
编辑
服务器启动日志中唯一可疑的条目是:
INFO: OpenJPA dynamically loaded a validation provider.
[LazyStopWebappClassLoader@5981f6b] warning javax.* types are not being woven because the weaver option '-Xset:weaveJavaxPackages=true' has not been specified
Dec 7, 2012 4:37:49 AM org.apache.catalina.util.LifecycleBase start
INFO: The start() method was called on component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[]] after start() had already been called. The second call will be ignored.
[LazyStopWebappClassLoader@5981f6b] error can't determine implemented interfaces of missing type javax.cache.Cache
when weaving type com.caucho.quercus.QuercusContext
when weaving classes
when weaving
[Xlint:cantFindType]
[LazyStopWebappClassLoader@5981f6b] error can't determine implemented interfaces of missing type com.google.appengine.api.users.UserService
when weaving type com.caucho.quercus.lib.gae.GaeUserService
when weaving classes
when weaving
[Xlint:cantFindType]
工作副本
斯坦尔是对的,也许是旧版本,但他们忘了添加开始
protected QuercusContext getQuercus()
{
synchronized (this) {
if (this._quercus == null) {
this._quercus = new QuercusContext();
this._quercus.start();
}
}
return this._quercus;
}
如果您想从java传递到php,那么必须使用env.setGlobalValue
斯坦尔是对的,也许是旧版本,但他们忘了添加开始
protected QuercusContext getQuercus()
{
synchronized (this) {
if (this._quercus == null) {
this._quercus = new QuercusContext();
this._quercus.start();
}
}
return this._quercus;
}
如果您想从java传递到php,那么您必须使用env.setGlobalValue我对Quercus不太熟悉,但是通过查看(第265行),计时器似乎没有实例化;(2042)耶。但是您得到的
NullPointerException
显示_querycustimer为null。可能永远不会调用start()
方法?好的。我想这可能就是问题所在。我认为QuercusView.java需要打包成一个jar文件并放到类路径中。我怀疑类加载的顺序有问题。为了在我的类路径中包含QuercusView,我现在所做的是在我的项目包结构中包含源文件。这样做我感觉不太好。我将它打包到一个罐子中,但它仍然不起作用。我不熟悉Quercus,但通过查看(第265行),计时器似乎没有实例化。请参见_quercusTimer=new quercusTimer();(2042)耶。但是您得到的NullPointerException
显示_querycustimer为null。可能永远不会调用start()
方法?好的。我想这可能就是问题所在。我认为QuercusView.java需要打包成一个jar文件并放到类路径中。我怀疑类加载的顺序有问题。为了在我的类路径中包含QuercusView,我现在所做的是在我的项目包结构中包含源文件。这样做我感觉不太好。我把它装进一个罐子里,但还是不起作用。谢谢。我后来从nam那里从Quercus邮件列表中得到了这个。谢谢。我后来从nam那里从Quercus邮件列表中得到了这个。
protected QuercusContext getQuercus()
{
synchronized (this) {
if (this._quercus == null) {
this._quercus = new QuercusContext();
this._quercus.start();
}
}
return this._quercus;
}