jsf - 如何创建 OmniFaces GraphicImage 方法的缩略图链接

标签 jsf thumbnails omnifaces graphicimage

我想知道是否以及如何显示 <o:graphicImage>作为 <p:lightbox> 内的缩略图。更准确地说,我想实现这样的目标:

<p:dataTable id="articles" var="article"
  value="#{articleMB.articles}" selectionMode="single"
  rowKey="#{articles.id}"
  selection="#{articleMB.selectedArticle}">
  <p:column>
    <p:lightBox styleClass="imagebox" id="lighbox">  
      <h:outputLink value="#{imageBean.getFirstImage(article, true)}">  
        <o:graphicImage value="#{imageBean.getFirstImage(article, true)}" dataURI="true" height="80" />  
      </h:outputLink>
     </p:lightBox>
   </p:column>
</p:dataTable>

这显然不起作用,因为没有正确的 URL 传递到灯箱。 imageBean.getFirstImage(Article article, boolean thumbnail)返回 byte[]图像的,因为我想要访问的图像存储在外部源上。


编辑:所以我已经按照 BalusC 提到的那样做了,这似乎是正确的方法。但现在我遇到了以下异常:

Caused by: java.lang.IllegalArgumentException: java.lang.ClassCastException@2eae887c 
    at sun.reflect.GeneratedMethodAccessor307.invoke(Unknown Source) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:497) 
    at org.omnifaces.resourcehandler.GraphicResource.getInputStream(GraphicResource.java:259) 
    at com.sun.faces.application.resource.ResourceHandlerImpl.handleResourceRequest(ResourceHandlerImpl.java:335) 
    at javax.faces.application.ResourceHandlerWrapper.handleResourceRequest(ResourceHandlerWrapper.java:153) 
    at org.primefaces.application.resource.PrimeResourceHandler.handleResourceRequest(PrimeResourceHandler.java:87) 
    at javax.faces.application.ResourceHandlerWrapper.handleResourceRequest(ResourceHandlerWrapper.java:153) 
    at javax.faces.application.ResourceHandlerWrapper.handleResourceRequest(ResourceHandlerWrapper.java:153) 
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:655) 
    ... 32 more

这是实际返回图像的方法。它在其他所有环境中都运行良好:

public byte[] getFirstImage(final Article article, boolean thumbnail)
{
    try
    {
        File dir = new File(getImageFolder(article.getImageFolder(), thumbnail));
        File[] files = dir.listFiles(new FilenameFilter()
        {
            @Override
            public boolean accept(File dir, String name)
            {
                return name.startsWith(String.valueOf(article.getArticleId()));
            }
        });
        Arrays.sort(files);
        return Files.readAllBytes(files[0].toPath());
    }
    catch (Exception e)
    {
        return new byte[1];
    }
}

编辑2:正如评论中提到的,我面临着另一种奇怪的行为。它在我的本地计算机上运行得很好,但在服务器上它抛出以下异常:

Caused by: java.lang.IllegalArgumentException: argument type mismatch
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at org.omnifaces.resourcehandler.GraphicResource.getInputStream(GraphicResource.java:259)
    at com.sun.faces.application.resource.ResourceHandlerImpl.handleResourceRequest(ResourceHandlerImpl.java:335)
    at javax.faces.application.ResourceHandlerWrapper.handleResourceRequest(ResourceHandlerWrapper.java:153)
    at org.primefaces.application.resource.PrimeResourceHandler.handleResourceRequest(PrimeResourceHandler.java:87)
    at javax.faces.application.ResourceHandlerWrapper.handleResourceRequest(ResourceHandlerWrapper.java:153)
    at javax.faces.application.ResourceHandlerWrapper.handleResourceRequest(ResourceHandlerWrapper.java:153)
    at javax.faces.webapp.FacesServlet.service(FacesServlet.java:655)
    ... 32 more

最佳答案

正是出于这个原因,OmniFaces 2.5 引入了 #{of:graphicImageURL()} EL 函数。仅当您的 ImageBean 使用 @GraphicImageBean 注解时,此方法才有效。

import org.omnifaces.cdi.GraphicImageBean;

@GraphicImageBean
public class ImageBean {

    // ...

}

<h:outputLink value="#{of:graphicImageURL('imageBean.getFirstImage(article, false)')}">  
    <o:graphicImage value="#{imageBean.getFirstImage(article, true)}" dataURI="true" height="80" />  
</h:outputLink>

另请参阅the @GraphicImageBean showcase .


更新:需要明确的是,您需要一个用于非标准类型(例如 Article)的转换器。为什么需要这样的转换器以及如何创建它在Conversion Error setting value for 'null Converter'中有详细介绍。 。如果您创建一个 @FacesConverter(forClass=Article.class),那么 OmniFaces GraphicImage 将自动拾取它。

在您的特定情况下,立即将标识符传递给图像流处理方法会更有效,这可以节省额外的转换步骤。假设您的 Article 对象具有 id 属性,操作方法如下:

<h:outputLink value="#{of:graphicImageURL('imageBean.getFirstImage(article.id, false)')}">  
    <o:graphicImage value="#{imageBean.getFirstImage(article.id, true)}" dataURI="true" height="80" />  
</h:outputLink>

public byte[] getFirstImage(Long articleId, boolean thumbnail) {
    // ...
}

也就是说,JSF 已经具有用于标准类型的内置转换器,例如 Longboolean

关于jsf - 如何创建 OmniFaces GraphicImage 方法的缩略图链接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39736390/

相关文章:

javascript - 单击 <p :commandButton> in JSF 打开一个新窗口

facebook - 如何让Facebook识别我的网页图片

javascript - 如何检测图像链接何时返回 404,但它仍然是有效图像

jsf-2 - 使用 Omnifaces <o :cache> 使数据过期

jsf - 我需要将 Primefaces AJAX 状态对话框的显示延迟 X 毫秒

css - 如何从 p :dataTable? 中删除 border-collapse

ajax - javax.crypto.BadPaddingException : Given final block not properly padded

jsf - org.omnifaces.facesviews.FacesViewsForwardingFilter 处的 NullPointerException

jsf - 在 JSF 中分配 'value expression' 代替 'method expression'

python - 有没有办法在不生成缩略图的情况下使用 sorl-thumbnail url?