c# c/s 管理系统
2012-01-24 00:02:52 cauchy 阅读数 2146
    当年硕导的观念影响下,很不喜欢做MIS(包括ERP/CRM之类)系统,最多只是做功能性软件。最近不得不做个小管理系统,而且得赶时间寒假间完成。虽然过去几年指导了过百学生做J2EE项目,可亲手做这样的系统是咱第一次。
    为了一些界面的功能,决定用MVP架构的C/S模式,而非B/S;程序语言C#;数据库SQLServer;另外,考虑到简易性和美观性,会在这个过程中用WPF/WCF/LINQ等模块。上述这些……我全部都没用过,第一次玩

    背景记录完毕,今天折腾一天,就是下载、安装设计、开发环境,以及跑通一个WPF下面连SQLServer的例子:
1. VS2008 + Visual Assistant安装正常;

2. PowerDesign安装正常,用它做概念化与实体化的数据模型设计(CDM/PDM),设计结果直接输出成建库的SQL语言。
    以前没用过数据库设计软件,今天看了这两个资料:

3. rational rose 7 安装异常:启动报错:无法启动此程序,因为计算机中丢失 suite objects.dll。
查到解决方案:http://blog.csdn.net/g5dsk/article/details/6754191,系统环境变量中的Path,里面那个rational rose路径的common要改成大写Common
建模工具rose 我以前没有用过,但是这些年下来,UML的活动图、时序图之类也看得不少了。所以没有专门再找教程,到时候直接画吧。之前用过另外一个轻量级的建模工具:Enterprise Architecture(EA),也挺不错的。这里有个教程:http://download.csdn.net/detail/xufanbb/1926283


4. 中间为了另外一个项目,安装matlab7出错,运行出现Runtime Error。经查也是环境变量的问题:
早上起得晚,解决完已经下午了。这里有个matlab帮助文档:http://download.csdn.net/detail/numenshane1/264691#comment

5. SQLServer2005
这个本来在VS2008里面带了一个Express版,但是后来用代码例子的时候死活连不通。最后找到解决方案:

不过注意,要用到微软的SQLServer管理工具:Microsoft SQL Server Management Studio Express,这个在VS2008里面没有,得去微软下载:
下载了又安装不上,直接运行安装文件出现错误码29506,再查解决方法,原来是要运行msiexec /i 后跟management studio安装程序的绝对路径,当然既可以在cmd命令行下做,也可以做个bat文件来运行:http://www.08.la/news2010/newshtml/JiShuWenZhang/MSSQL/12173.html

此外,很多网上教程,包括MSDN,对SQLServer开发都用到了AdventureWorks这个数据库做例子,为方便又特意去下载了这个数据库,选了SQL server 2005版的:
注意,AdventureWorksDB.msi文件安装运行以后,还需要在Management Studio里面选“数据库”->右键->“属性”->“附加”,将mdf文件添加进去以后在sql服务器里面才看到这个库。mdf文件的默认安装目录见下图:

 

图片

 



6. WPF例子
我找到了这个教程,一个最简单的WPF例子。还包括了连接数据库。
里面有几个地方:

 void getData()

        {

            //init sqlconnection

            SqlConnectionStringBuilder connbuilder = new SqlConnectionStringBuilder();

            connbuilder.DataSource = "(local)";

            connbuilder.IntegratedSecurity = true;

            connbuilder.InitialCatalog = "AdventureWorks";

            ......

        }

这里的(local)实际上要写成数据库所在的机器名,例如我的是"MYLAPOTP\\SQLEXPRESS", 没有括号。而且,它的连接方式是默认用windows账户登录,可以改成:

            connbuilder.IntegratedSecurity =  false ;

            connbuilder.InitialCatalog = " AdventureWorks ";

            connbuilder.UserID = " sa ";

            connbuilder.Password = " 1234 ";

原文中:

接下来我们就来实现这部分功能。

1)      为了简化代码,在WrapPanel元素中指明一个公共的上下文,可以通过增加属性

 DataContext="{Binding ElementName=listView1,Path=SelectedItem}

 这一行的代码最后面少了个双引号。

7. 今天还找了一些相关资料的网址:
关于C/S架构的网址:http://www.csframework.com/welcome.htm
用WCF-WPF-LINQ来做office应用的例子:http://msdn.microsoft.com/zh-cn/magazine/cc163292.aspx#S6
2012-01-17 02:30:22 iteye_13347 阅读数 33
c#获取路径 c/s
2011年09月09日
  一、获取当前文件的路径
  1. System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName
  获取模块的完整路径,包括文件名。
  2. System.Environment.CurrentDirectory
  获取和设置当前目录(该进程从中启动的目录)的完全限定目录。
  3. System.IO.Directory.GetCurrentDirectory()
  获取应用程序的当前工作目录。这个不一定是程序从中启动的目录啊,有可能程序放在C:/www里,这个函数有可能返回C:/Documents and Settings/ZYB/,或者C:/Program Files/Adobe/,有时不一定返回什么东东,这是任何应用程序最后一次操作过的目录,比如你用Word打开了E:/doc/my.doc这个文件,此时执行这个方法就返回了E:/doc了。
  4. System.AppDomain.CurrentDomain.BaseDirectory
  获取程序的基目录。
  5. System.AppDomain.CurrentDomain.SetupInformation.ApplicationBase
  获取和设置包括该应用程序的目录的名称。
  6. System.Windows.Forms.Application.StartupPath
  获取启动了应用程序的可执行文件的路径。效果和2、5一样。只是5返回的字符串后面多了一个"/"而已
  7. System.Windows.Forms.Application.ExecutablePath
  获取启动了应用程序的可执行文件的路径及文件名,效果和1一样。
  二、操作环境变量
  利用System.Environment.GetEnvironmentVariable()方法可以很方便地取得系统环境变量,如:
  System.Environment.GetEnvironmentVariable("windir")就可以取得windows系统目录的路径。
  以下是一些常用的环境变量取值:
  System.Environment.GetEnvironmentVariable("windir");
  System.Environment.GetEnvironmentVariable("INCLUDE");
  System.Environment.GetEnvironmentVariable("TMP");
  System.Environment.GetEnvironmentVariable("TEMP");
  System.Environment.GetEnvironmentVariable("Path");
  最后贴出我进行上面操作获得的变量值,事先说明,本人是编写了一个WinForm程序,项目文件存放于D:/Visual Studio Projects/MyApplication/LifeAssistant,编译后的文件位于D:/Visual Studio Projects/MyApplication/LifeAssistant/bin/Debug,最后的结果如下:
  1、System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName=D:/Visual Studio Projects/MyApplication/LifeAssistant/bin/Debug/LifeAssistant.exe
  2、System.Environment.CurrentDirectory=D:/Visual Studio Projects/MyApplication/LifeAssistant/bin/Debug
  3、System.IO.Directory.GetCurrentDirectory()=D:/Visual Studio Projects/MyApplication/LifeAssistant/bin/Debug
  1 asp.net webform用“Request.PhysicalApplicationPath获取站点所在虚拟目录的物理路径,最后包含“/”;
  2.c# winform用
  A:“Application.StartupPath”:获取当前应用程序所在目录的路径,最后不包含“/”;
  B:“Application.ExecutablePath ”:获取当前应用程序文件的路径,包含文件的名称;
  C:“AppDomain.CurrentDomain.BaseDirectory”:获取当前应用程序所在目录的路径,最后包含“/”;
  D:“System.Threading.Thread.GetDomain().BaseDirectory”:获取当前应用程序所在目录的路径,最后包含“/”;
  E:“Environment.CurrentDirectory”:获取当前应用程序的路径,最后不包含“/”;
  F:“System.IO.Directory.GetCurrentDirectory”:获取当前应用程序的路径,最后不包含“/”;
  3.c# windows service用“AppDomain.CurrentDomain.BaseDirectory”或“System.Threading.Thread.GetDomain().BaseDirectory”;
  用“Environment.CurrentDirectory”和“System.IO.Directory.GetCurrentDirectory”将得到“ system32”目录的路径;
  如果要使用“Application.StartupPath”或“Application.ExecutablePath ”,需要手动添加对“System.Windows.Forms.dll ”的引用,并在程序开头用“using System.Windows.Forms”声明该引用;
  4.在卸载程序获取系统安装的目录:
  System.Reflection.Assembly curPath = System.Reflection.Assembly.GetExecutingAssembly();
  string path=curPath.Location;//得到安装程序类SetupLibrary文件的路径,获取这个文件路径所在的目录即得到安装程序的目录;
  4、System.AppDomain.CurrentDomain.BaseDirectory=D:/Visual Studio Projects/MyApplication/LifeAssistant/bin/Debug/
  5、System.AppDomain.CurrentDomain.SetupInformation.ApplicationBase=D:/Visual Studio Projects/MyApplication/LifeAssistant/bin/Debug/
  6、System.Windows.Forms.Application.StartupPath=D:/Visual Studio Projects/MyApplication/LifeAssistant/bin/Debug
  7、System.Windows.Forms.Application.ExecutablePath=D:/Visual Studio Projects/MyApplication/LifeAssistant/bin/Debug/LifeAssistant.exe
  System.Environment.GetEnvironmentVariable("windir")=C:/WINDOWS
  System.Environment.GetEnvironmentVariable("INCLUDE")=C:/Program Files/Microsoft Visual Studio .NET 2003/SDK/v1.1/include/
  System.Environment.GetEnvironmentVariable("TMP")=C:/DOCUME~1/zhoufoxcn/LOCALS~1/Temp
  System.Environment.GetEnvironmentVariable("TEMP")=C:/DOCUME~1/zhoufoxcn/LOCALS~1/Temp
  System.Environment.GetEnvironmentVariable("Path")=C:/WINDOWS/system32;C:/WINDOWS;C:/WINDOWS/System32/Wbem;C:/jdk1.5.0/bin;C:/MySQLServer5.0/bin;C:/Program Files/Symantec/pcAnywhere/;C:/Program Files/Microsoft SQL Server/80/Tools/BINN
  C# 相对路径 系统路径
  2007-12-22 09:53
  //获取启动了应用程序的可执行文件的路径,不包括可执行文件的名称。
  string str5=Application.StartupPath;
  //可获得当前执行的exe的文件名。
  string str1 =Process.GetCurrentProcess().MainModule.FileName;
  //获取和设置当前目录(即该进程从中启动的目录)的完全限定路径。备注 按照定义,如果该进程在本地或网络驱动器的根目录中启动,则此属性的值为驱动器名称后跟一个尾部反斜杠(如“C:/”)。如果该进程在子目录中启动,则此属性的值为不带尾部反斜杠的驱动器和子目录路径(如“C:/mySubDirectory”)。
  string str2=Environment.CurrentDirectory;
  //获取应用程序的当前工作目录。
  string str3=Directory.GetCurrentDirectory();
  //获取基目录,它由程序集冲突解决程序用来探测程序集。
  string str4=AppDomain.CurrentDomain.BaseDirectory;
  //获取启动了应用程序的可执行文件的路径,不包括可执行文件的名称。
  string str5=Application.StartupPath;
  //获取启动了应用程序的可执行文件的路径,包括可执行文件的名称。
  string str6=Application.ExecutablePath;
  //获取或设置包含该应用程序的目录的名称。
  string str7=AppDomain.CurrentDomain.SetupInformation.ApplicationBase;
  //例子
  Application.StartupPath;
  //可以得到F:/learning/c#Training/win/win/bin/Debug
  //注意自己补两个/
  Application.StartupPath+"//3.jpg";
  在c#中,相对路径是用"."和".."表示,
  "."代表当前目录,
  ".."代表上一级录。
  例如 假设我用vs2005在D:/My Documents/Visual Studio 2005/Projects目录里创建了一个名叫controls的项目,即在Projects文件夹里有一个controls文件夹,controls文件夹里有三个文件:controls.sln controls文件夹 GulfOfStLawrence文件夹。
  D:/My Documents/Visual Studio 2005/Projects/Controls/Controls/bin/Debug是这个简单项目能够运行的可执行文件Controls.exe
  现在我想要 D:/My Documents/Visual Studio 2005/Projects/Controls/GulfOfStLawrence文件夹下的Gulf_of_St._Lawrence.mxd(arcgis desktop)工程文件路径。
  那么相对路径应该就是"../../../GulfOfStLawrence/Gulf_of_St._Lawrence.mxd"
  即string filename = @"../../../GulfOfStLawrence/Gulf_of_St._Lawrence.mxd";
  心得:1.用相对路径能增加项目的可移植性。使一个工程在移植过程中变得简单,节省了大量布置与工程相关的文件的时间。(如果设置的是绝对路径)。
  2.使用相对路径也使程序代码变得简单
  3. 但有一点必须注意:(只能在同一个驱动器里(如:都在D:里)使用相对路径)。
2008-09-23 17:14:00 cocojiji5 阅读数 3357
    目前遇到个非常头痛的问题,公司目前有多个应用系统,采用C#,Java,C++,C,VB,等等语言开发的应用系统,为了解决多个应用系统之间的登陆问题,打算采用SSO解决登陆问题,做成单点登陆,只要登陆其中任何一个系统,就可以访问其他系统的资源和服务,这些应用系统中有采用b/s、和c/s,对于b/s的应用,cas可以很方便的解决各系统间登陆的问题,麻烦出在c/s上,
比如说:
    C#系统的c/s,可以通过http协议访问cas的登陆认证请求,但是却是一个短连接,无法保证长连接,C#可以模拟IE,向cas登陆页面发送一个请求进行登陆,却无法得到登陆成功后返回的ticket,cas为每个web应用分配了各自不同的ticket,这个ticket,可以被使用,去访问不同的web应用,而C#的c/s结构中却无法获取到这个ticket,也导致无法使用cas client中的代理校验,我所期望的方案,是否cas可以通过Web Service的方式,通过soap,进行登陆和服务访问呢,从目前的cas client中,好象没有该解决方案。
    不知道谁有更好的解决方案,可以帮助我解决目前的烦恼吗?不仅仅限制于cas,如果有更好的解决方案,我也可以采用,请尽量说的详细一点,可以在评论中给我回复,小妹,先谢过各位大虾
2007-12-02 10:35:00 nnsword 阅读数 617

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

/// <summary>
/// MD5 的摘要说明
/// </summary>
public class MD5
{
 public MD5()
 {
  //
  // TODO: 在此处添加构造函数逻辑
  //
 }
    public static string get(string str, int code)
    {
        if (code == 16) //16位MD5加密(取32位加密的9~25字符)
        {
            return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5").ToLower().Substring(8, 16);
        }
        else//32位加密
        {
            return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5").ToLower();
        }
    }
}
 

2008-01-02 09:03:00 taokai 阅读数 454

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

/// <summary>
/// MD5 的摘要说明
/// </summary>
public class MD5
{
 public MD5()
 {
  //
  // TODO: 在此处添加构造函数逻辑
  //
 }
    public static string get(string str, int code)
    {
        if (code == 16) //16位MD5加密(取32位加密的9~25字符)
        {
            return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5").ToLower().Substring(8, 16);
        }
        else//32位加密
        {
            return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5").ToLower();
        }
    }
}
 

C# C/S与B/S揭秘

阅读数 131

没有更多推荐了,返回首页