Maison > Questions et réponses > le corps du texte
P粉2519031632023-08-28 18:47:50
Voyons ce qui se passe étape par étape :
. src
. src
属性需要指向有效的 http://
doit pointer vers une URL http://
valide, donc pas vers un chemin du système de fichiers du disque local file://http://example.com/context/images/foo.png
)或作为请求参数(例如 http://example.com/context/images?id=1
Les URL d'image doivent inclure l'identifiant de l'image dans le chemin de la requête (par exemple http:// exemple.com/context/images?id=1
). /images/*
Dans le monde JSP/Servlet, vous pouvez demander à un servlet d'écouter un modèle d'URL spécifique, tel que byte[]
或 InputStream
的形式获取,JDBC API 提供 ResultSet#getBytes()
和 ResultSet#getBinaryStream()
< /a> 为此,JPA API 提供@Lob
Les images sont des données binaires qui peuvent être obtenues à partir de la base de données sous la forme byte[] ou 李>InputStream, API JDBCbyte[]
或 InputStream
写入响应的 OutputStream
ResultSet#getBytes() et ResultSet#getBinaryStream()< /a> Pour ce faire, API JPAContent-Type
响应头也需要设置。您可以通过 ServletContext#getMimeType()
基于图像文件扩展名,您可以通过 web.xml 中的
扩展和/或覆盖该扩展名
InputStream dans le OutputStream de la réponse (de la manière habituelle Java IO
.
Le client doit être invité à gérer les données comme une image, donc au moins l'en-tête de réponse src
Content-Type doit également être défini. Vous pouvez obtenir le type correct via
<img src="${pageContext.request.contextPath}/images/foo.png">
<img src="${pageContext.request.contextPath}/images/bar.png">
<img src="${pageContext.request.contextPath}/images/baz.png">
🎜Si nécessaire, vous pouvez également utiliser les paramètres dynamiques 🎜EL🎜 🎜="https://stackoverflow.com/tags/jstl/info">JSTL🎜 : 🎜<c:forEach items="${imagenames}" var="imagename">
<img src="${pageContext.request.contextPath}/images/${imagename}">
</c:forEach>
Ensuite, définissez/créez un servlet qui écoute sur /images/*< URL 模式上的 GET 请求/code>, l'exemple suivant utilise JDBC simple pour faire le travail :
@WebServlet("/images/*") public class ImageServlet extends HttpServlet { // content=blob, name=varchar(255) UNIQUE. private static final String SQL_FIND = "SELECT content FROM Image WHERE name = ?"; @Resource(name="jdbc/yourDB") // For Tomcat, define as <Resource> in context.xml and declare as <resource-ref> in web.xml. private DataSource dataSource; @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String imageName = request.getPathInfo().substring(1); // Returns "foo.png". try (Connection connection = dataSource.getConnection(); PreparedStatement statement = connection.prepareStatement(SQL_FIND)) { statement.setString(1, imageName); try (ResultSet resultSet = statement.executeQuery()) { if (resultSet.next()) { byte[] content = resultSet.getBytes("content"); response.setContentType(getServletContext().getMimeType(imageName)); response.setContentLength(content.length); response.getOutputStream().write(content); } else { response.sendError(HttpServletResponse.SC_NOT_FOUND); // 404. } } } catch (SQLException e) { throw new ServletException("Something failed at SQL/DB level.", e); } } }
C'est tout. Si vous vous inquiétez des en-têtes HEAD et du cache et que vous répondez correctement à ces demandes, utilisez ce Modèle abstrait pour les servlets de ressources statiques.