用ASP.NET实现简单的文字水印

代码如下:
ExpandedBlockStart.gifContractedBlock.gif<%@ Import Namespace = Namespace="System" %> 
ExpandedSubBlockStart.gifContractedSubBlock.gif
<%@ Import Namespace =
Namespace="System.IO" %> 
ExpandedSubBlockStart.gifContractedSubBlock.gif
<%@ Import Namespace =
Namespace="System.Drawing" %> 
InBlock.gif
InBlock.gif
<%@ Page language="vb" %>

InBlock.gif
InBlock.gif
<script runat="server">
InBlock.gif    
Dim FilePath As String = Server.MapPath("FengEr.jpg")
InBlock.gif    
ExpandedSubBlockStart.gifContractedSubBlock.gif    
Sub Page_Load()
Sub Page_Load(Sender As Object, E As EventArgs)
InBlock.gif        
Dim image As System.Drawing.Image =
 System.Drawing.Image.FromFile( FilePath )
InBlock.gif        
Dim g As Graphics =
 Graphics.FromImage(image)
InBlock.gif        g.DrawImage(image, 
00
, image.Width, image.Height)
InBlock.gif        
Dim f As Font = new Font("华文行楷"30
)
InBlock.gif        
Dim b As Brush = new
 SolidBrush(Color.Green)
InBlock.gif        
Dim s As String = Request.QueryString("Str"
)
InBlock.gif        g.DrawString(s, f, b, 
20290
)
InBlock.gif        image.Save(Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg)
InBlock.gif        g.Dispose()
InBlock.gif        image.Dispose()
ExpandedSubBlockEnd.gif    
End Sub
    
InBlock.gif
</script>

只要把这个代码存成一个aspx文件,比如Test.aspx。然后放到wwwroot里面(假设你的虚拟目录是默认的)。再做一个Test.jpg的图片,就可以在(20, 290)这个位置打印出“华文行楷”这种字体的文字了。调用方法很简单:

http://localhost/Test.aspx?Str=Dicky's Blog!

对于打印的位置和字体还有图片文件都是可以自己设定的。另外,如果出现了以英文作为参数就可以正常显示,而对于中文就无法显示的情况,是因为Asp.net的web.config设置不正确造成了,需要进行如下设置:

None.gif <? xml version="1.0" encoding="utf-8" ?>
None.gif
< configuration >
None.gif    
< system .web >
None.gif    
< globalization  requestEncoding ="gb2312"  responseEncoding ="gb2312"  culture ="zh-CN"  fileEncoding ="gb2312" />
None.gif    
</ system.web >
None.gif
</ configuration >

这样,就可以正常显示了。

转载于:https://www.cnblogs.com/Dicky/archive/2005/03/16/122366.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值