标签归档:ASP.NET

InnerHtml无法获取内部内容,因为该内容不是文本

在后台获取dataDiv的innerHtml时,
如果直接写dataDiv.innerHtml,而dataDiv有runat=server的控件,就会报错,
因此需要用下面的方法来实现。
1.添加一个方法
    public override void VerifyRenderingInServerForm(Control control)
    {
    } 
2.在需要取到innerHtml的地方写代码如下
        System.Text.StringBuilder strb = new System.Text.StringBuilder();
        System.IO.StringWriter sw = new System.IO.StringWriter(strb);
        System.Web.UI.HtmlTextWriter htw = new HtmlTextWriter(sw);
        dataDiv.RenderControl(htw);
        string str = strb.ToString();//str即为所需值。

来自:http://apps.hi.baidu.com/share/detail/48942033

ASP.NET多种调用javascript脚本的方法

ASP.NET本身就提供了多种调用javascript脚本的方法,笔者在这里总结了六种调用方法,大家可以根据自己的使用习惯选择相应的调用方式了!

1、直接在前台页面调用自定义的javascript 函数:

很简单,在 head 元素之间加入 script 元素,将 type 元素设置为 ” text/javascript ”

如:

<head runat=”server”>
<script type=”text/javascript” >
function ShowName(str)
{
alert(“十万个为什么的站长是:(“+str+”)”);
}
</script>
<title>using javascript</title>
</head>

之后在body 元素间,通过事件来访问,比如要通过button1 的单击事件(onclientclick)来访问 javascript 函数的ShwoName()的示例如下:

<asp:Button ID=”Button1″ runat=”server” Text=”Button” onclientclick=”ShowName(‘伍锐锋’)” />

这时运行项目,单击 button时,会显示”十万个为什么,的站长是:伍锐锋”
这就是在前端页面直接定义及调用javascript函数.

2、在前台通过引入js文件来调用相应的函数:

方法与(1)一样,只不过需要指定要调用的js 文件

示例如下:

<head runat=”server”>
<script type=”text/javascript” src=”kenscript.js”>
</script>
<title>using javascript</title>
</head>

之后在body 元素间,通过事件来访问, 比如要通过button1 的单击事件(onclientclick)来访问 javascript 函数的示例如下:

//此时 .js文件中必须有 ShowName 方法

<asp:Button ID=”Button1″ runat=”server” Text=”Button” onclientclick=”ShowName(‘伍锐锋’)” />

3、在后台调用 javascript 函数,函数在.js文件中

前台的head 元素

<head runat=”server”>
<script type=”text/javascript” src=”kenscript.js”>
</script>
<title>using javascript</title>
</head>

后台的需要添加如下代码

Button1.Attributes.Add(“onclick”, “showname1(‘伍锐锋’)”);

4、在后台调用 javascript 函数,函数写在对应的js文件中,但并没有在前台定义,示例如下:

//获得.js文件

string myscript = “kenscript.js”;

//注册.js文件

Page.ClientScript.RegisterClientScriptInclude(“myKey”, myscript);

如果此时查看源码,会得到如下代码

//<script src =”kenscript.js” type=”text/javascript”><script>

//同上
Button1.Attributes.Add(“onclick”, “showname1(‘伍锐锋’)”);

5. 用Response.Write方法写入脚本

比如在你单击按钮后,先操作数据库,完了后显示已经完成,可以在最后想调用的地方写上
Response.Write(“<script type=’text/javascript’>alert(“操作完成!”);</script>”);

不过呢,这个方法有个缺陷就是不能调用脚本文件中的自定义的函数,只能调用内部函数,具体调用自定义的函数只能在Response.Write写上 函数定义,比如Response.Write(“<script type=’text/javascript’>function myfun(){…}</script>”);

6.用ClientScript类动态添加脚本

用法如下:在想调用某个javascript脚本函数的地方添加代码,注意要保证MyFun已经在脚本文件中定义过了。

ClientScript.RegisterStartupScript(ClientScript.GetType(), “myscript”, “<script>MyFun();</script>”);

这个方法比Response.Write更方便一些,可以直接调用脚本文件中的自定义函数,不过跟前面几种相比没那么简洁直观。

注意,以上所有方法中,后台代码都不能有转化当前页的代码,比如Redirect等,要把转页代码放在脚本里面.

http://blog.sina.com.cn/s/blog_67e0571d0100m8vn.html

 

asp.net分页,ASPNETPager用法

1.添加DLL引用,文件名为:AspNetPager.dll。
2.在aspx文件中添加<%@ RegisterAssembly=”AspNetPager” Namespace=”Wuqi.Webdiyer”TagPrefix=”webdiyer” %>代码,下面是分页样式代码:

<div id=”PagerStyle”>
<webdiyer:AspNetPager ID=”AspNetPager1″runat=”server” OnPageChanging=”AspNetPager1_PageChanging”Width=”95%” PageSize=”20″ AlwaysShow=”True” FirstPageText=”首页”LastPageText=”尾页” NextPageText=”下一页” PrevPageText=”上一页”ShowCustomInfoSection=”Left” ShowInputBox=”Never”CustomInfoTextAlign=”Right”CssClass=”paginator”
CurrentPageButtonClass=”cpb” CustomInfoHTML=”当前第 %CurrentPageIndex%/ %PageCount% 共 %PageCount%页 每页 %PageSize% 条记录”AlwaysShowFirstLastPageNumber=”True”LayoutType=”Table”>
</webdiyer:AspNetPager>
</div>

3.在CS文件中写using Wuqi.Webdiyer;
4.获取数据源,下面是获得数据的一个方法,BLL.Trunk.GetAllList方法是一个封装过的方法,返回一个DataSet结果集,这个方法自己写就可以,这是来自项目中的代码:

private void LoadData()
{
DataSet ds =BLL.Trunk.GetAllList();
PagedDataSource pds = newPagedDataSource();
pds.AllowPaging =true;//设置允许分页
pds.DataSource =ds.Tables[0].DefaultView;//设置分页的数据源
AspNetPager1.RecordCount = pds.Count;//AspNetPager1.RecordCount =ds.Tables[0].DefaultView.Count;等价//获取数据的条数
pds.CurrentPageIndex = AspNetPager1.CurrentPageIndex -1;//设置当前页的索引
pds.PageSize =AspNetPager1.PageSize;//设置每页显示的页数
gvData.DataSource = pds;
gvData.DataBind();
}

5.事件分页改变代码:

protected void AspNetPager1_PageChanging(object src,PageChangingEventArgs e)
{
this.AspNetPager1.CustomInfoHTML = string.Format(“当前第{0}/{1}页共{2}条记录 每页{3}条”, new object[] { this.AspNetPager1.CurrentPageIndex+ 1, this.AspNetPager1.PageCount, this.AspNetPager1.RecordCount,this.AspNetPager1.PageSize});
AspNetPager1.CurrentPageIndex =e.NewPageIndex;
LoadData();
}

http://www.cnblogs.com/chinawinner/archive/2011/01/20/tt144.html

 

C#.Net调用非托管的DLL

一、DLL介绍:

动态链接库(DLL,即“Dynamic Link Library”)是Microsoft Windows最重要的组成元素之一,打开windows系统文件夹,会发现很多DLL文件,windows就是将一些主要的系统功能以DLL模块的形式实现。动态链接库是不能直接执行的,也不能接收消息,它是一个独立的文件,其中包含被程序或其他DLL调用来完成一定操作的函数(方法)。但这些函数不是执行程序本身的一部分,而是根据进程的需要按需载入,此时才能发挥作用。

二、C#.Net调用基本格式:

[DLLImport(“DLL文件路径”)]

修饰符 extern 返回值类型 方法名称(参数列表) 如:

[DllImport(“kernel32.dll”, SetLastError = true, EntryPoint = “SetLocalTime”)]
public static extern int SetSystemTime(ref SystemTime lpSystemTime);

PS:

1、DLL文件必须位于程序当前目录或系统定义的查询路径中(即:系统环境变量中Path所设置的路径)。

2、DLLImport会按照顺序去查找DLL文件(程序当前目录>System32目录>环境变量Path所设置路径)。

3、返回类型变量、方法名称、参数列表一定要与DLL文件中的定义相一致。

4、Asp.net DLLImport路径—-使用第三方非托管的DLL(Charles.dll)组件的时候,当把Charles.dll拷贝到Bin目录下,提示仍然提示仍然找不到该dll.(而这样[DLLImport(@“C:ProgramDirCharles.dll”)]可以正常加载)。Asp.Net Team的官方解决方案如下:

首先需要确认引用了哪些组件?哪些是托管的?那些是非托管的?

托管的很方便,直接被使用的需要引用,间接使用的需要拷贝到Bin目录下。非托管的就特殊处理(实际上你拷贝到bin是没有任何作用的,因为CLR会把文件拷贝到一个临时目录下,然后在那运行Web,而CLR只会拷贝托管文件,这就是为什么把非托管的DLL放到bin目录下仍然提示找不到该模块)。

解决方案:首先在服务器上建立一个新建的目录,假设是(C:ProgramDirWinDLL).然后在环境变量中,给Path变量添加这个目录,最后把非托管的DLL文件都拷贝到该目录下。或者更干脆把DLL放到System32目录中。对于自己部署的应用程序,这样的确能很好的解决问题。然而如果我们用的是虚拟空间,我们有没有办法吧注册Path变量或者把我们自己的DLL拷贝System32目录下。同时我们也不一定知道我们DLL的物理路径.

DLLImport里面只能用字符常量,而不能使用Server.MapPath来确认物理绝对路径。

这样的话我们需要动态的取得我们DLL的物理路径(Server.MapPath),并通过API来取得DLL里面的函数(先加载LoadLibrary后获得函数地址GetProcAddress)。相关的API如下:

Public Class CustomDLLInvoke

{

[DLLImport(“kernel32.dll”)]

private extern static IntPtr LoadLibrary(string path);

[DLLImport(kernel32.dll)]

private extern static IntPtr GetProcAddress(IntPtr lib,String funcName);

[DLLImport(Kernel32.dll)]

private extern static bool FreeLibrary(IntPtr lib);

private IntPtr MLib;

public CustomDLLInvoke(string dllPath)

{MLib=LoadLibrary(DLLPath)}

~CustomDLLInvoke(){FreeLibrary(MLib);}

public Delegate Invoke(string APIName,Type t)

{IntPtr api=GetProAddress(MLib,APIName);return (Delegate)Marshal.GetDelegateForFunctionPointer(api,t);}

}

三、消息回调

函数的两种调用方式:

StdCall:stdcall调用约定又称为passcal调用约定,其调用约定申明的语法为:int_stdcall function(int a,int b).stdcall的调用约定意味着:1.参数从右向左压入堆栈。2.函数自身修改堆栈。3.函数名自动加前导的下划线,后面紧跟一个@符号。其后紧跟着参数的尺寸。在C#中,函数只支持stdcall的调用方式。

Cdecl:cdecl调用约定又称为C调用约定,是C语言缺省的调用约定,它的定义语法是:int_cdecl function(int a,int b).cdecal调用约定的参数压栈顺序和stdcall是一样的。参数首先由右向左压入堆栈。所不同的是,函数本身不清理堆栈,调用者复制清理堆栈。由于这种变化,C调用约定允许函数的参数的个数是不固定的,这也是C语言的一大特色。VC++ 6.0默认使用cdecl的调用方式。

所以当C#通过消息回调dll函数时候,由于函数调用的约定不同,函数不能正确的调用。

采取方式:1.修改dll文件,支持stdCall的调用方式。2.手工方式修改.il中间文件(C#不支持_cdecl修饰符,可.net中间文件.il是支持cdecl的调用方式。)cdecl

3.用VC++ 7.0给windows dll封装一层外壳。(在VC++ 7.0中,可以通过_cdecl修饰符,指定函数的调用方式)

四、复杂类型Demo示例(修改PC机的系统时间)

ModifyTime

public struct SystemTime
{
public short wYear;
public short wMonth;
public short wDayOfWeek;
public short wDay;
public short wHour;
public short wMinute;
public short wSecond;
public short wMilliseconds;
}

[DllImport(“kernel32.dll”, SetLastError = true, EntryPoint = “SetLocalTime”)]
public static extern int SetSystemTime(ref SystemTime lpSystemTime);

[DllImport(“kernel32.dll”, SetLastError = true)]
public static extern long GetLastError();

private void button1_Click(object sender, EventArgs e)
{
DateTime setdt=DateTime.Parse(this.textBox1.Text);
SystemTime st = new SystemTime();
st.wYear = (short)setdt.Year;
st.wMonth = (short)setdt.Month;
st.wDay =(short) setdt.Day;
st.wHour = (short)setdt.Hour;
st.wMinute =(short)setdt.Minute;
st.wSecond =(short) setdt.Second;
int result = SetSystemTime(ref st);
if (result == 1)
{
MessageBox.Show(“修改成功!”);
}
else
{
long errorCode = GetLastError();
//int code = Marshal.GetLastWin32Error();//.net常用这种方式代替GetLastError API
MessageBox.Show(“修改失败,Win32错误代码是{0},请查看GetLastError返回值的意义列表或调用FormatMessage查看” + errorCode.ToString());
}
}

 

 

PS:

1、SetLocalTime与SetSystemTime的区别:SetLocalTime的用法与SetSystemTime基本相同,差别在于SetSystemTime所带的参数指定的是UTC时间(国际标准时间),也就是说,针对我们地区的电脑(东八区),这样的话,使用SysteSystemTime设置后,系统的时间,会比参数所设置的时间快8个小时)

2、GetLastError返回值的意义(http://blog.chinaunix.net/u2/82288/showart_1335456.html)

Best Regards,

Charles Chen

http://www.cnblogs.com/Charles2008/archive/2010/01/10/1643449.html

 

在.net C#里调用非托管动态库函数dll

有一个动态库:Dog.dll中个函数(只有这个函数):int DogIsValid() ,用VC6开发确认已经导出来,也就是说在别的地方能调用。

然后在C#里用如下代码调用:

using System.Runtime.InteropServices;

[DllImport(“Dog.dll”)] public static extern int DogIsValid();

再在函数中使用

private void Page_Load(object sender, System.EventArgs e) {

// 在此处放置用户代码以初始化页面

if(DogIsValid() != 1) { lbErrorMsg.Text = “加密狗不存在。”; } }

报错:无法在 DLL Dog.dll 中找到名为 DogIsValid的入口点。

解决方案:

.Net提供了类型库导入程序(Tlbimp.exe),将在 COM 类型库中找到的类型定义转换为托管元数据格式中的等效定义。 先转换吧,然后在项目中引用Dog.dll

可能你的: [DllImport(“Dog.dll”)] public static extern int DogIsValid(); 要该为: [DllImport(“Dog.dll”)] static extern int DogIsValid(); 去掉public 这里有一个类试的解决方法: 这里讲述的是C#调用标准动态库的问题, 在我以前的文件中讲到过, C#调用Win32API, 原理是一样的. 这里我详细讲解用C写一个标准的动态库, 然后让C#调用. (本篇适合初学者, 中间没有任何冗余代码, 简洁明了) 软件环境: VC6.0(当然其他版本的VC5也可以) 1.制作标准动态库 __declspec(dllexport) int __cdecl add(int, int);//这一句是声明动态库输出一个可供外不调用的函数原型. int add(int a,int b) {//实现这个函数 return a+b; } 以上简单3行代码,声明一个add的方法, 输入参数是两个int参数,返回这两个数之和. 保存为MyLib.c 然后执行编译命令. H:XSchoolC#-SchoolHowTo>cl /LD MyLib.c Microsoft (R) 32-bit C/C++ Optimizing Compiler Version 12.00.8168 for 80×86 Copyright (C) Microsoft Corp 1984-1998. All rights reserved. MyLib.c Microsoft (R) Incremental Linker Version 6.00.8447 Copyright (C) Microsoft Corp 1992-1998. All rights reserved. /out:MyLib.dll /dll /implib:MyLib.lib MyLib.obj Creating library MyLib.lib and object MyLib.exp 确信有以上输出, 说明编译成功生成了动态库. 2.编写C-Sharp程序调用该动态库 using System; using System.Runtime.InteropServices;//这是用到DllImport时候要引入的包 public class InvokeDll { [DllImport(“MyLib.dll”, CharSet=CharSet.Auto)] static extern int add(int a,int b);//声明外部的标准动态库, 跟Win32API是一样的. public static void Main() { Console.WriteLine(add(10,30)); } } 保存为InvokeDll.cs文件, 与MyLib.dll置于同一目录, 编译该文件. H:XSchoolC#-SchoolHowTo>csc invokedll.cs 将生成Invokedll.exe, 可以执行该文件.