Servlet实现动态图文结合输出

servlet|动态

如果你是一个WEB开发者,或多或少会遇到这样一种情况:网页设计师在设计网页时,在需要动态输出内容的地方采用图片,如下图:

而\\\\"热点聚焦"这个名称,也许过一两天就要求改成"焦点访谈"等其它字样,到时不得不重新制作一张图片替代。而采用文字加背景,有时不易达到好的效果。采用表格背景图方式,需要精心调整表格的尺寸,而且其它的改动也会有意无意影响到它,需要小心调试。

本人在多个项目开发中遇到网页中需要动态图文结合输出情况,程序员和美工往往最终都是选择了回避和妥协,尽管通常影响不大,但毕竟与尽善尽美的追求有所差距。于是终于产生了本文的解决方法。

先看看我们要解决的问题\\

我们的问题可以简单总结为:有一张图片,如:

现在我们要动态地将文字比如\\\\"热点聚焦"输出到上面,并在网页上得到类似如下的显示:

HTML如何显示一张图片
在HMTL中显示一张图片很简单:<img src=http://www.163design.net/j/f/"bg.jpg" weight="153" height="25">。

另外我们还知道src属性中的文件类型并没有做限定,也就是说<img src="image.jsp">的写法也是合法的,同样引用Servlet:<img src="/imageServlet">的写法也是合法的,浏览器解析到该语句时,将向目标服务器发送一个HTTP请求。通过了解HTTP协议,可以知道,如果这时imageServlet做出Content-Type为image/jpeg的正确响应(可以通过设置contentType="images/jpeg"来实现),那么也将正确显示一张图片。这个原理也是实现将数据库中的图像数据显示到网页上所用的原理。

进一步利用这个原理,当向imageServlet请求图像时,imageServlet不是简单的发送原图像数据,而是先对原图像数据进行一定的处理,比如在原图片上面的指定位置加上文字,甚至对再做一些处理比如阴影、立体等,然后再将处理后的图像数据流发送出去,那么不就可以得到图文结合后的图像了吗?

根据以上分析,我们得到这样的实现方法:在<img>的src属性中调用实现上述功能的Servlet并传递相关的参数,如背景图片路径、输出文字、文字输出的位置、字体、大小等,由该Servlet进行图文处理,并返回处理后的图像数据,从而在网页上显示出加上文字的图像。

通过Servlet实现图文结合输出\\

下面根据上面的原理编写一个简单的Servlet实现代码,该Servlet能够根据传递的参数要求,将文字输出到图片上并向浏览器返回图文结合后的图像数据,并在调用的网页上显示出图文结合后的图像(注:该servlet仅实现了JPG格式图像文件的处理,不支持GIF):

package net.xdevelop.merge;import javax.servlet.*;import javax.servlet.http.*;import java.io.*;import java.util.*;import java.awt.*;import java.awt.image.*;import com.sun.image.codec.jpeg.*;import net.xdevelop.util.ParamUtil;/** * 将文字用指定的字体,颜色和大小,嵌入指定图片的指定位置,调用参数: * text: 要嵌的文字 * imageFile: JPG图片的虚拟路径 * x: 文字输出的起始X坐标位置 * y: 文字输出的起始Y坐标位置 * fontColor: 字体颜色(例fontColor=FFFFFF) * fontSize: 字体大小 * fontStyle: 字体风格(斜体,粗体等) * fontName: 字体名称(如仿宋体,宋体等) */public class TextIntoImage extends HttpServlet { private static final String CONTENT_TYPE = "image/jpeg;charset=GB2312"; public void init() throws ServletException { } /** Process the HTTP Get request */ public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doPost(request,response); } //--------------------------------------------------------------------------------------------- /** Process the HTTP Post request */ public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType(CONTENT_TYPE); String text = ""; //要嵌的文字 String imageFile = ""; //被嵌的图片的虚拟路径 int x = 0; //坐标\\ int y = 0; String fontColor = ""; //字体颜色 int fontSize = 0; //字体大小 String fontStyle = ""; //字体风格(斜体,粗体等) String fontName = ""; //字体名称 try { //取得参数(ParamUtil类请参看后面附的ParamUtil类代码) text = ParamUtil.getParameter(request,"text"); imageFile = ParamUtil.getParameter(request,"imageFile"); x = ParamUtil.getIntParameter(request,"x",0); y = ParamUtil.getIntParameter(request,"y",0); fontColor = ParamUtil.getParameter(request,"fontColor"); fontSize = ParamUtil.getIntParameter(request,"fontSize",16); fontStyle = ParamUtil.getParameter(request,"fontStyle"); fontName = ParamUtil.getParameter(request,"fontName"); } catch(Exception e) { e.printStackTrace(); } ServletOutputStream output=response.getOutputStream(); if(imageFile.toLowerCase().endsWith(".jpeg")||imageFile.toLowerCase().endsWith(".jpg")) { imageFile = getServletContext().getRealPath(imageFile); InputStream imageIn = new FileInputStream(new File(imageFile)); JPEGImageDecoder decoder = JPEGCodec.createJPEGDecoder(imageIn); BufferedImage image = decoder.decodeAsBufferedImage(); Graphics g=image.getGraphics(); //设置颜色 g.setColor(new Color(Integer.parseInt(fontColor,16))); //设置字体\\ Font mFont = new Font(fontName,Font.PLAIN,fontSize);//默认字体\\ if(fontStyle.equalsIgnoreCase("italic")) mFont=new Font(fontName,Font.ITALIC,fontSize); if(fontStyle.equalsIgnoreCase("bold")) mFont=new Font(fontName,Font.BOLD,fontSize); if(fontStyle.equalsIgnoreCase("plain")) mFont=new Font(fontName,Font.PLAIN,fontSize); g.setFont(mFont); //输出文字 g.drawString(text,x,y); //输出数据流\\ JPEGImageEncoder encoder = JPEGCodec.createJPEGEncoder(output); encoder.encode(image); imageIn.close(); } output.close(); }}//////////

上面获取参数的代码使用了一个工具类,它是扩展了request.getParameter()功能的一个类:

package net.xdevelop.util;import javax.servlet.*;public class ParamUtil { /** * 获得request中指定名称的参数值,若有中文乱码问题请增加转码部分 * @param request ServletRequest对象\\ * @param paramName 参数名称 * @return 如果该变量值存在则返回该值,否则返回"" */ public static String getParameter( ServletRequest request, String paramName ) { String temp = request.getParameter(paramName); if( temp != null && !temp.equals("") ) { //若有中文问题,在此添加转码代码,例:temp = new String(temp.getBytes("8859_1"), "GB2312"); return temp; } else { return ""; } } /** * 获得request中的int型参数值 * @param request ServletRequest对象\\ * @param paramName 参数名称 * @param defaultNum 默认值,如果没有返回该值 * @return 如果该参数值存在则返回其转换为int型的值,否则返回defaultNum */ public static int getIntParameter( ServletRequest request, String paramName, int defaultNum ) { String temp = request.getParameter(paramName); if( temp != null && !temp.equals("") ) { int num = defaultNum; try { num = Integer.parseInt(temp); } catch( Exception ignored ) { } return num; } else { return defaultNum; } }}///////////

实际应用

在web.xml中声明该Servlet

<servlet> <servlet-name>textintoimage</servlet-name> <servlet-class>net.xdevelop.merge.TextIntoImage</servlet-class></servlet><servlet-mapping> <servlet-name>textintoimage</servlet-name> <url-pattern>/TextIntoImage</url-pattern></servlet-mapping>

将net.xdevelop.merge.TextIntoImage类和net.xdevelop.util.ParamUtil类放入WEB-INF/classes/
JSP页面调用,本例中要将bg.jpg文件放入根目录,示例代码: <img border="0" src=http://www.163design.net/j/f/"/TextIntoImage?text=热点聚焦&imageFile=/bg.jpg&x=20&y=20&fontColor=FFFFFF&fontStyle=bold&fontName=宋体&fontSize=16">
继续完善
到此可以暂告一个段落了。不过还有很多地方有待继续完善,例如:加入文字效果处理(阴影、立体、浮雕等),文字竖排,增加对GIF文件支持等。

本文代码下载:demo.zip

时间: 2024-12-07 19:46:08

Servlet实现动态图文结合输出的相关文章

c++ 如何动态的决定输出的宽度

问题描述 c++ 如何动态的决定输出的宽度 用setw()的时候,当里面是一个变量名的时候,显示的宽度是自动的,并不是设定的. int w = 6; cout << setw(w) << 9.8 << endl; 输出并不是6个宽度,什么原因,怎么样才能让这样的设定生效? 解决方案 可以用变量的啊 http://blog.csdn.net/goodnew/article/details/6337455 你是不是后面的内容超过长度了,先输出较短的字符串验证一下. 解决方案

用jsp+servlet制作动态网页

问题描述 用jsp+servlet制作动态网页 有哪位大神有做过Discuz论坛吗用jsp................................... 解决方案 Discuz论坛用的是php 不过你可以google下找到很多jsp的论坛代码. 解决方案二: JSP , Servlet 和动态网页. 1. 使用Servlet 可以产生动态网页,但是需要在代码中打印输出很多HTML的标签. ??? ->即,将静态显示的内容和动态产生的内容全部放到代码中. 2. 在静态的网页文件中嵌入脚本代

PHP中动态HTML的输出技术

你可以在php程序中的任何地方使用 echo "hello world!"; 来输出你想输出的内容. 不过你将遇到以下麻烦: 1 - 当你试图在hello和world之间加入两个(或两个以上)空格, 你使用: echo "hello world!"; 你得到的输出还是一个空格,或者你在行首加入一个空格, 你的空格也将被忽略. 2 - 更糟的是输出用户输入的内容时,有心或无意的用户输入将 使你的输出变的一团糟,甚至给其他用户带来麻烦. 比如: <form act

PHP中动态HTML的输出技术_php基础

你可以在php程序中的任何地方使用 echo "hello world!"; 来输出你想输出的内容. 不过你将遇到以下麻烦: 1 - 当你试图在hello和world之间加入两个(或两个以上)空格, 你使用: echo "hello world!"; 你得到的输出还是一个空格,或者你在行首加入一个空格, 你的空格也将被忽略. 2 - 更糟的是输出用户输入的内容时,有心或无意的用户输入将 使你的输出变的一团糟,甚至给其他用户带来麻烦. 比如: <form act

servlet保存数据到session输出到页面

 代码如下 复制代码 <script>   $(document).ready(function(){//页面载入时像servlet请求数据    $.post('../Order.do', {     action: 'OrderMsg',     s: $("#s").val(),     v: $("#v").val()     }, function(data) {       reurl();//返回数据时刷新页面一次(因为数据保存在sessi

控制动态servlet图形处理(2)

servlet|动态|控制|图形 编写定制 JSP 标记 既然明白了 Web 服务器是如何处理 JSP 页面请求的,那么让我们研究一下如何实现定制 JSP 标记.注:JSP 标记既来自标准库(如 Java Standard Template Library,JSTL),也来自您自己编写的库(也称为定制标记).通常,定制标记处理特殊的问题领域.对本文而言,我们在处理如何管理图像.目前,Java 2 Extended Edition(J2EE)V1.2 和 V1.3 使用 JSP 规范 V1.2.在

控制动态servlet图形处理(1)

servlet|动态|控制|图形 控制世界-或者至少控制您的图像 作为一名站点开发人员或页面作者,迎合所有这些喜好是很困难的.要手工执行该工作,必须将站点上的每个图像转换成您的网站支持的图像大小.然后,需要调整站点上每个页面中的图像标记,使每个标记都正确地反映图像的大小.不能只更改 HTML img 标记的宽(width)和高(height),而不更改图像:这会导致低带宽用户下载大的图像,并在客户机端重新调整它的大小.如果提供了八个常用的图像大小,很容易可以看到每个图像将如何需要八个缩放大小,以

Sparks.com用XML和XSL来生成动态页面

xml|动态|页面 XML(可扩展标记语言)看起来可能像某种W3C标准--现在没有什么实际影响,即使以后能派上用场,也是很久以后的事.但实际上,它现在已经得到了应用.所以,不要等到XML已被加进了你最喜爱的HTML编辑器中才开始使用它.它现在就可以解决各种内部问题和B2B系统问题. 在Sparks.com,我们使用XML来标准化从Java对象到HTML数据显示等不同系统之间的数据表示. 特别需要指出的是,我们发现,只要以非常基本的XML结构来实现标准化,就可以更容易地共享和操作数据.在这一过程中

Servlet简介

Servlet是Java技术在CGI编程方面的一个解决之道.Servlet是在服务器端运行的程序,可产生动态的内容输出,相对于使用传统的CGI编程,Servlets有不少的优点: 效率:使用传统的CGI编程,对于每个HTTP请求都会打开一个新的进程,这样将会带来性能和扩展性的问题.使用Servlets,由于Java VM(Java虚拟机)是一直运行的,因此开始一个Servlet只会创建一个新的Java线程而不是一个系统进程 功能强大--相对于传统的CGI,由于有着广泛的Java API支持,Se