2009年8月26日
var returnVal = window.showModalDialog(url,args,'dialogHeight: ' + height + 'px;dialogWidth:' + width + 'px;status:no;help:no;resizable:yes;scroll:yes;center:yes;');
if (returnVal=="True")
{
window.location.href=window.location.href;
window.location.reload();
}
然后在打开的窗口中
<script>window.returnValue='True';window.close();</script>
最近做的项目中有客户需求 要把资料进行A~Z,AA~AZ,BA~BZ。。。。的自动归档。
算法思路:26位进制
class Program
{
private static char[] arr = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' };
static void Main(string[] args)
{
string input = Console.ReadLine();
while (input.Length > 0)
{
input = input.ToUpper();
Console.WriteLine(NextLetter(input));
input = Console.ReadLine();
}
}
private static string NextLetter(string input)
{
char[] arr_input = input.ToCharArray(); // 将输入字符转成字符数组
// 保存结果的数组,考虑产生进位的情况,长度+1
// 结果数组保存的不是字符,是保存字符的索引号
int[] arr_index = new int[arr_input.Length + 1];
// 初始化结果数组
for (int i = 0; i < arr_index.Length; i++)
{
arr_index[i] = -1;
}
// 第一步:先将输入字符数组转化成字符索引号保存到结果数组
int j = 0;
for (int i = arr_input.Length - 1; i >= 0; i--)
{
arr_index[j] = LetterIndex(arr_input[i]);
j++;
}
// 对结果数组进行+1操作, 采用26进制, +1操作后的结果数组就是 后续编号 对应的索引号
j = 0;
arr_index[j] = arr_index[j] + 1;
while (arr_index[j] % 26 == 0 && j < arr_input.Length)
{
arr_index[j] = arr_index[j] % 26;
j++;
if (arr_index[j-1] == 0)
arr_index[j] = arr_index[j] + 1;
}
// 将字符索引号转化成对应的字符返回
string next = "";
for (int i = arr_index.Length - 1; i >= 0; i--)
{
if (arr_index[i] >= 0)
next += arr[arr_index[i]].ToString();
}
return next;
}
private static int LetterIndex(char letter)
{
int index = 0;
for (index = 0; index < arr.Length; index++)
{
if (letter == arr[index])
break;
}
return index;
}
}
add
<base target="_self"/>
in the <head>
2009年7月24日
今天打开IE发现自动打开了网站www.1188.com, 进入IE的选项修改默认首页, 发现默认首页还是about:blank,
没有被篡改; 然后进入regedit, 查看IE的相关设置是否有被修改成www.1188.com的值, 也没发现, 很是奇怪,
对1188进行全注册表扫描, 竟然也没发现。 猜测是否中毒了,或中了木马。
进入google搜索有关www.1188.com的恶意修改信息, 也没发现有价值的, 只有一帖是说通过360safe来修复IE来
解决的, 无奈下只能安装360试试看, 下载安装后, 捣腾了半个多小时, 也没发现有木马, 也没有解决这个问题。
1. 中了最新的病毒, Bitdefender病毒库尚无记载;(我用的是bitdefender防火墙)
2. 中了木马, Bitdefender 和 360 目前都没有发现的木马;
3. 这个1188是通过其他方式来控制ie的默认首页的
确定了以上基本情况后, 打开ie再看一下1188这个网站, 无意中发现打开ie到显示1188这个网站中间存在一个ie跳转
的情况, 于是通过ie的后退按钮, 终于发现了这个罪恶的源头是www.abc127.com这个网址, 1188就是通过这个网址上
跳转过来的,顿时很佩服。
在注册表中搜索abc127, 在一个starthomepage的项里找到了这个网站的信息, 是通过设置ie后面的参数来实现的,
删除这个键值, 再打开ie, OK,搞定。
感触:
1. 在病毒肆虐的今天, 遇到这种情况, 大家第一感觉是中了病毒或木马了, 第一时间是去找杀毒软件或杀木马的
软件,但有时候我们眼睛看到的不一定就是真实。
2. 伪装的手段从简单慢慢的演变到现在的复杂, 大家已经对复杂的伪装手段习以为常了, 用这个一很简单的手段来
伪装,伪装者真的很聪明。
我们在系统设计还是在编程的时候, 遇到很复杂问题的是否, 应该静下心来, 把复杂的问题一层层来化解,让复杂
成为简单, 要透过表面那些眼花缭乱的现象, 寻找现象底下的根本性的东西,解决了源头,一切都能OK。
2009年6月25日
STSDEV
http://www.codeplex.com/stsdev
CodePlex上有视频使用介绍,在某些方面比微软的VS Extensions好用的多……
快速生成各种SharePoint解决方案项目,比如Feature啊,WebPart啊。生成的VS工程是包含着WSP的,而且支持各种build选项。
【经常在使用的时候需要去查找, 转摘记录一下作为备忘录。】
我们在呈现数据的时候,不要将未经修饰过的数据呈现给使用者。例如金额一万元,如果我们直接显示「10000」,可能会导致使用者看成一千或十万,造成使用者阅读数据上的困扰。若我们将一万元润饰后输出为「NT$10,000」,不但让使比较好阅读,也会让使用者减少犯错的机会。
下列画面为润饰过的结果:
上述数据除了将DataGrid Web 控件以颜色来区隔记录外,最主要将日期、单价以及小计这三个计字段的数据修饰的更容易阅读。要修饰字段的输出,只要设定字段的DataFormatString 属性即可;其使用语法如下:
DataFormatString="{0:格式字符串}"
我们知道在DataFormatString 中的 {0} 表示数据本身,而在冒号后面的格式字符串代表所们希望数据显示的格式;另外在指定的格式符号后可以指定小数所要显示的位数。例如原来的数据为「12.34」,若格式设定为 {0:N1},则输出为「12.3」。其常用的数值格式如下表所示:
格式字符串 资料 结果
"{0:C}" 12345.6789 $12,345.68
"{0:C}" -12345.6789 ($12,345.68)
"{0:D}" 12345 12345
"{0:D8}" 12345 00012345
"{0:E}" 12345.6789 1234568E+004
"{0:E10}" 12345.6789 1.2345678900E+004
"{0:F}" 12345.6789 12345.68
"{0:F0}" 12345.6789 12346
"{0:G}" 12345.6789 12345.6789
"{0:G7}" 123456789 1.234568E8
"{0:N}" 12345.6789 12,345.68
"{0:N4}" 123456789 123,456,789.0000
"Total: {0:C}" 12345.6789 Total: $12345.68
其常用的日期格式如下表所示:
格式 说明 输出格式
d 精简日期格式 MM/dd/yyyy
D 详细日期格式 dddd, MMMM dd, yyyy
f 完整格式 (long date + short time) dddd, MMMM dd, yyyy HH:mm
F
完整日期时间格式
(long date + long time)
dddd, MMMM dd, yyyy HH:mm:ss
g 一般格式 (short date + short time) MM/dd/yyyy HH:mm
G 一般格式 (short date + long time) MM/dd/yyyy HH:mm:ss
m,M 月日格式 MMMM dd
s 适中日期时间格式 yyyy-MM-dd HH:mm:ss
t 精简时间格式 HH:mm
T 详细时间格式 HH:mm:ss