选项1
与其更改CSS文件,不如根据会话应用不同的类。
.main
{
padding: 0px 12px;
margin: 0px 0px 0px 0px;
min-height: 630px;
width:auto;
}
.agency1 { background-image: url('agency1.png'); }
.agency2 { background-image: url('agency2.png'); }
.agency3 { background-image: url('agency3.png'); }
然后在您的 div 中添加两个类
<div class="main <%=Session["agency"]%>"></div>
选项2
创建一个通用处理程序,呈现特定的CSS并将其添加到您的页面中
<link href="GenerateCss.ashx" rel="stylesheet" />
在你的 GenerateCss.ashx.cs 文件中,你会有类似这样的内容。
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
string image = "main";
if (context.Session != null && context.Session["agency"] != null)
{
image = context.Session["agency"].ToString();
}
string result = ".main{padding: 0px 12px; margin: 0px 0px 0px 0px; min-height: 630px; width:auto; background-image:url('" + image + ".png');}";
context.Response.Write(result);
}
非常小心,如果使用不当,这可能会为您设置XSS攻击 您需要确保session["agency"]不受用户控制。也就是说,用户不能提供该值,因为这将允许他们注入任何他们想要的内容。
我不建议使用第二个选项,因为您将为每个请求调用它,而且在可以使其静态的情况下不断生成CSS并不是一个好主意。如果您可以使用选项1,我认为它会更好。