这个问题是关于在asp.net webforms应用程序中使用static修饰符 我是一个初学者,虽然我从未遇到过这个静态“问题”的问题 我仍然不担心这个问题,并希望清除这一点。
最近我开始使用Ajax/jQuery
POST代替asp.net
'正常'回发
所以我可以利用javascript对象,并在与服务器交互时避免页面刷新
我的问题是关于ajax帖子。它使用静态方法 将信息返回给用户
有关客户端代码的一些背景信息...(如果您愿意,可以跳到下面的服务器端)
客户方:
HTML
<td id="TD_Actions_<%=RecordIdSlot%>" class="RepTblDataTds ">
<!-- will be used to trigger jquery function instead of asp imageButton that causes a postback
<span id="SpanEditRecord">
<img src="img/EditPic.png" style="width:20px;" class="CssClassImgBut_Edit" />
</span>
</td>
jquery:
var SpanEditRecord = $('#SpanEditRecord'); // the trigger span
// onclick event post data to code behind
SpanEditRecord.click(function () {
var Recid = $(this).parent().attr('id').split('_')[2];// takes the Sql table RecordiD
var data = [];
data.push({ key: 'RecordId', value: parseInt(Recid) }); //usually there's more data in "data"
var targetUrl = "default.aspx/EditKkRecord";
$.ajax({
type: 'POST',
url: targetUrl,
data: JSON.stringify({ SentPars: data }),
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (response) {
getResponseFromEditRequest(response.d);
},
error: function (response) {
alert(response.status + ' ' + response.statusText);
}
});
});
//handle callback /response from C# server side code
function getResponseFromEditRequest(htmlret) {
var packagerec = htmlret.split(',');
........
........
}
现在讨论相关话题..
C#服务器端
这部分是有问题的,
使用它和几个用户时[WebMethod]
是不安全的吗?
它是否会意外地共享相同的返回值,因为它是一个静态方法?
[WebMethod]
public static string EditKkRecord(object SentPars)
{
Dictionary<string, string> NwDataDict = new Dictionary<string, string>();
string tmpSQLstr = "";
try
{
Array aa = (Array)SentPars;
foreach (Dictionary<string, object> pair in aa)
{
NwDataDict.Add((string)pair["key"], pair["value"].ToString());
}
}
catch (Exception ex)
{
return ex.Message;
}
if (NwDataDict.Count > 0)
return EditRecordFromtblKupaKtanaDb(NwDataDict);
return tmpSQLstr;
}
static string EditRecordFromtblKupaKtanaDb(Dictionary<string, string> todayKupa)
{
interact with database;
return "comaSeparated - columns values as a string";
}
在这种情况下,用户a,b和c会触发该Web方法并共享相同的返回值,如果他们都尝试编辑相同的“RecordId”
或甚至更糟(我能想到),如果他们都编辑不同的记录,实际上行动可以从第一个用户共享...相同的记录..
什么时候使用static
实际上不安全?在此代码中它是否不安全?
答案 0 :(得分:6)
将方法作为静态运行是安全的,只要它不依赖于静态方法之外的静态变量。
这是一个如何在asp.net Web应用程序中不使用静态的示例:
public static string SaveSomething;
public static void DoSomething()
{
SaveSomething = "something";
//... do more code
AnotherAction(SaveSomething);
}
首先将SaveSomething字符串属性设置为您的值。同时,该属性可以由另一个请求/用户设置,因为它共享该属性。现在,如果您回忆该属性并将其用于AnotherAction,则它可能与您最初设置的值不同。如果要使用对外部静态变量的引用,则必须确保这些变量以这种方式安全使用。大多数情况下它们都是只读的。
但是可以使用lock语句锁定属性:
public static string SaveSomething;
public static void DoSomething()
{
lock (SaveSomething)
{
SaveSomething = "something";
//... do more code
AnotherAction(SaveSomething);
}
}