本文整理汇总了C#中DotNetNuke.Entities.Urls.FriendlyUrlSettings类的典型用法代码示例。如果您正苦于以下问题:C# FriendlyUrlSettings类的具体用法?C# FriendlyUrlSettings怎么用?C# FriendlyUrlSettings使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
FriendlyUrlSettings类属于DotNetNuke.Entities.Urls命名空间,在下文中一共展示了FriendlyUrlSettings类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: Log404
/// <summary>
/// Logs the 404 error to a table for later checking
/// </summary>
/// <param name="request"></param>
/// <param name="settings"></param>
/// <param name="result"></param>
public static void Log404(HttpRequest request, FriendlyUrlSettings settings, UrlAction result)
{
var controller = new LogController();
var log = new LogInfo
{
LogTypeKey = EventLogController.EventLogType.PAGE_NOT_FOUND_404.ToString(),
LogPortalID = (result.PortalAlias != null) ? result.PortalId : -1
};
log.LogProperties.Add(new LogDetailInfo("TabId", (result.TabId > 0) ? result.TabId.ToString() : String.Empty));
log.LogProperties.Add(new LogDetailInfo("PortalAlias", (result.PortalAlias != null) ? result.PortalAlias.HTTPAlias : String.Empty));
log.LogProperties.Add(new LogDetailInfo("OriginalUrl", result.RawUrl));
if (request != null)
{
if (request.UrlReferrer != null)
{
log.LogProperties.Add(new LogDetailInfo("Referer", request.UrlReferrer.AbsoluteUri));
}
log.LogProperties.Add(new LogDetailInfo("Url", request.Url.AbsoluteUri));
log.LogProperties.Add(new LogDetailInfo("UserAgent", request.UserAgent));
log.LogProperties.Add(new LogDetailInfo("HostAddress", request.UserHostAddress));
log.LogProperties.Add(new LogDetailInfo("HostName", request.UserHostName));
}
controller.AddLog(log);
}
示例2: CheckForModuleProviderRedirect
/// <summary>
/// Checks for a redirect based on a module friendly url provider rule
/// </summary>
/// <param name="requestUri"></param>
/// <param name="result"></param>
/// <param name="queryStringCol"></param>
/// <param name="settings"></param>
/// <param name="parentTraceId"></param>
/// <returns></returns>
internal static bool CheckForModuleProviderRedirect(Uri requestUri,
ref UrlAction result,
NameValueCollection queryStringCol,
FriendlyUrlSettings settings,
Guid parentTraceId)
{
var messages = new List<string>();
string location;
bool redirected = ExtensionUrlProviderController.CheckForRedirect(requestUri,
result,
queryStringCol,
settings,
out location,
ref messages,
parentTraceId);
if (messages != null)
{
result.DebugMessages.AddRange(messages);
}
if (redirected)
{
result.FinalUrl = location;
result.Action = ActionType.Redirect301;
result.Reason = RedirectReason.Custom_Redirect;
}
return redirected;
}
示例3: BindAction
public void BindAction(int portalId, int tabId, int moduleId)
{
var providers = ExtensionUrlProviderController.GetProviders(portalId);
Localization.LocalizeDataGrid(ref providersGrid, LocalResourceFile);
providersGrid.DataSource = providers;
providersGrid.DataBind();
UrlSettingsExtensionControl.BindAction(portalId, tabId, moduleId);
var settings = new DotNetNuke.Entities.Urls.FriendlyUrlSettings(portalId);
if (settings.EnableCustomProviders == false)
{
providersGrid.Visible = false;
providersWarningLabel.Visible = true;
providersWarningLabel.Text = LocalizeString("ExtensionProvidersDisabled.Text");
}
else
{
if (providersGrid.Items.Count == 0)
{
providersGrid.Visible = false;
providersWarningLabel.Visible = true;
providersWarningLabel.Text = LocalizeString("NoProvidersInstalled.Text");
}
}
}
示例4: RewriteUrl
internal override void RewriteUrl(object sender, EventArgs e)
{
Guid parentTraceId = Guid.Empty;
const bool debug = true;
bool failedInitialization = false;
bool ignoreForInstall = false;
var app = (HttpApplication) sender;
try
{
//875 : completely ignore install/upgrade requests immediately
ignoreForInstall = IgnoreRequestForInstall(app.Request);
if (ignoreForInstall == false)
{
_settings = new FriendlyUrlSettings(-1);
SecurityCheck(app);
}
}
catch (Exception ex)
{
//exception handling for advanced Url Rewriting requests
failedInitialization = true;
DotNetNuke.Services.Exceptions.Exceptions.LogException(ex);
if (app.Context != null)
{
ShowDebugData(app.Context, app.Request.Url.AbsoluteUri, null, ex);
Handle404OrException(_settings, app.Context, ex, null, false, debug);
}
else
{
throw;
}
}
if (!failedInitialization && !ignoreForInstall)
{
//if made it through there and not installing, go to next call. Not in exception catch because it implements it's own top-level exception handling
var request = app.Context.Request;
//829 : change constructor to stop using physical path
var result = new UrlAction(request)
{
IsSecureConnection = request.IsSecureConnection,
IsSSLOffloaded = IsSSLOffloadEnabled(request),
RawUrl = request.RawUrl
};
ProcessRequest(app.Context,
app.Context.Request.Url,
Host.Host.UseFriendlyUrls,
result,
_settings,
true,
parentTraceId);
}
}
示例5: ProcessRequest
private void ProcessRequest(FriendlyUrlSettings settings, UrlTestHelper testHelper)
{
var provider = new AdvancedUrlRewriter();
provider.ProcessTestRequestWithContext(HttpContext.Current,
HttpContext.Current.Request.Url,
true,
testHelper.Result,
settings);
testHelper.Response = HttpContext.Current.Response;
}
示例6: IsExcludedFromFriendlyUrls
/// <summary>
/// Determines if the tab is excluded from FriendlyUrl Processing
/// </summary>
/// <param name="tab"></param>
/// <param name="settings"></param>
/// <param name="rewriting">If true, we are checking for rewriting purposes, if false, we are checking for friendly Url Generating.</param>
/// <returns></returns>
private static bool IsExcludedFromFriendlyUrls(TabInfo tab, FriendlyUrlSettings settings, bool rewriting)
{
//note this is a duplicate of another method in RewriteController.cs
bool exclude = false;
string tabPath = (tab.TabPath.Replace("//", "/") + ";").ToLower();
if (settings.UseBaseFriendlyUrls != null)
{
exclude = settings.UseBaseFriendlyUrls.ToLower().Contains(tabPath);
}
return exclude;
}
示例7: GetAliasByPortalIdAndSettings
/// <summary>
/// Returns the chosen portal alias for a specific portal Id and culture Code
/// </summary>
/// <param name="aliases"></param>
/// <param name="portalId"></param>
/// <param name="cultureCode"></param>
/// <remarks>Detects the current browser type if possible. If can't be deteced 'normal' is used. If a specific browser type is required, use overload with browser type.</remarks>
/// <returns></returns>
public static PortalAliasInfo GetAliasByPortalIdAndSettings(this IEnumerable<PortalAliasInfo> aliases, int portalId, UrlAction result, string cultureCode, FriendlyUrlSettings settings)
{
var browserType = BrowserTypes.Normal;
//if required, and possible, detect browser type
if (HttpContext.Current != null && settings != null)
{
HttpRequest request = HttpContext.Current.Request;
HttpResponse response = HttpContext.Current.Response;
browserType = FriendlyUrlController.GetBrowserType(request, response, settings);
}
return GetAliasByPortalIdAndSettings(aliases, portalId, result, cultureCode, browserType);
}
示例8: GetProvidersToCall
/// <summary>
/// Returns the providers to call. Returns tabid matches first, and any portal id matches after that.
/// </summary>
/// <param name="tabId"></param>
/// <param name="portalId"></param>
/// <param name="settings"></param>
/// <param name="parentTraceId"></param>
/// <returns></returns>
private static List<ExtensionUrlProvider> GetProvidersToCall(int tabId,
int portalId,
FriendlyUrlSettings settings,
Guid parentTraceId)
{
List<ExtensionUrlProvider> providers;
//887 : introduce lockable code to prevent caching race errors
lock (providersBuildLock)
{
bool definitelyNoProvider;
//887 : use cached list of tabs instead of per-tab cache of provider
//get the list of providers to call based on the tab and the portal
var providersToCall = CacheController.GetProvidersForTabAndPortal(tabId,
portalId,
settings,
out definitelyNoProvider,
parentTraceId);
if (definitelyNoProvider == false && providersToCall == null)
//nothing in the cache, and we don't have a definitive 'no' that there isn't a provider
{
//get all providers for the portal
var allProviders = GetModuleProviders(portalId).Where(p => p.ProviderConfig.IsActive).ToList();
//store the list of tabs for this portal that have a provider attached
CacheController.StoreListOfTabsWithProviders(allProviders, portalId, settings);
//stash the provider portals in the cache
CacheController.StoreModuleProvidersForPortal(portalId, settings, allProviders);
//now check if there is a provider for this tab/portal combination
if (allProviders.Count > 0)
{
//find if a module is specific to a tab
providersToCall = new List<ExtensionUrlProvider>();
providersToCall.AddRange(allProviders);
}
}
//always return an instantiated provider collection
providers = providersToCall ?? (new List<ExtensionUrlProvider>());
}
//return the collection of module providers
return providers;
}
示例9: CancelRedirect
/// <summary>
/// Cancels a redirect
/// </summary>
/// <param name="result"></param>
/// <param name="context"></param>
/// <param name="settings"></param>
/// <param name="message"></param>
internal static void CancelRedirect(ref UrlAction result, HttpContext context, FriendlyUrlSettings settings, string message)
{
result.Action = ActionType.Continue;
result.Reason = RedirectReason.Not_Redirected;
result.FinalUrl = null;
//clean the path for the rewrite
NameValueCollection queryString = null;
if (context != null)
{
queryString = context.Request.QueryString;
}
result.RewritePath = RedirectTokens.RemoveAnyRedirectTokens(result.RewritePath, queryString);
//redo the rewrite to fix up the problem. The user has ticked 'permanent redirect' but hasn't supplied a forwarding Url
if (context != null)
//if no context supplied, means no rewrite was required because querystring didn't contain do301 action
{
//RewriterUtils.RewriteUrl(context, result.RewritePath, settings.RebaseClientPath);
RewriterUtils.RewriteUrl(context, result.RewritePath);
}
result.DebugMessages.Add(message);
}
示例10: GetOptionsFromSettings
/// <summary>
/// Return a FriendlyUrlOptions object from the provider settings
/// </summary>
/// <param name="settings"></param>
/// <returns></returns>
public static FriendlyUrlOptions GetOptionsFromSettings(FriendlyUrlSettings settings)
{
var options = new FriendlyUrlOptions
{
PunctuationReplacement = (settings.ReplaceSpaceWith != FriendlyUrlSettings.ReplaceSpaceWithNothing)
? settings.ReplaceSpaceWith
: String.Empty,
SpaceEncoding = settings.SpaceEncodingValue,
MaxUrlPathLength = 200,
ConvertDiacriticChars = settings.AutoAsciiConvert,
RegexMatch = settings.RegexMatch,
IllegalChars = settings.IllegalChars,
ReplaceChars = settings.ReplaceChars,
ReplaceDoubleChars = settings.ReplaceDoubleChars,
ReplaceCharWithChar = settings.ReplaceCharacterDictionary,
PageExtension = (settings.PageExtensionUsageType == PageExtensionUsageType.Never)
? ""
: settings.PageExtension
};
return options;
}
示例11: IdentifyPortalAlias
private void IdentifyPortalAlias(HttpContext context,
HttpRequest request,
Uri requestUri, UrlAction result,
NameValueCollection queryStringCol,
FriendlyUrlSettings settings,
Guid parentTraceId)
{
//get the domain name of the request, if it isn't already supplied
if (request != null && string.IsNullOrEmpty(result.DomainName))
{
result.DomainName = Globals.GetDomainName(request); //parse the domain name out of the request
}
// get tabId from querystring ( this is mandatory for maintaining portal context for child portals )
if (queryStringCol["tabid"] != null)
{
string raw = queryStringCol["tabid"];
int tabId;
if (Int32.TryParse(raw, out tabId))
{
result.TabId = tabId;
}
else
{
//couldn't parse tab id
//split in two?
string[] tabids = raw.Split(',');
if (tabids.GetUpperBound(0) > 0)
{
//hmm more than one tabid
if (Int32.TryParse(tabids[0], out tabId))
{
result.TabId = tabId;
//but we want to warn against this!
var ex =
new Exception(
"Illegal request exception : Two TabId parameters provided in a single request: " +
requestUri);
UrlRewriterUtils.LogExceptionInRequest(ex, "Not Set", result);
result.Ex = ex;
}
else
{
//yeah, nothing, divert to 404
result.Action = ActionType.Output404;
var ex =
new Exception(
"Illegal request exception : TabId parameters in query string, but invalid TabId requested : " +
requestUri);
UrlRewriterUtils.LogExceptionInRequest(ex, "Not Set", result);
result.Ex = ex;
}
}
}
}
// get PortalId from querystring ( this is used for host menu options as well as child portal navigation )
if (queryStringCol["portalid"] != null)
{
string raw = queryStringCol["portalid"];
int portalId;
if (Int32.TryParse(raw, out portalId))
{
//848 : if portal already found is different to portal id in querystring, then load up different alias
//this is so the portal settings will be loaded correctly.
if (result.PortalId != portalId)
{
//portal id different to what we expected
result.PortalId = portalId;
//check the loaded portal alias, because it might be wrong
if (result.PortalAlias != null && result.PortalAlias.PortalID != portalId)
{
//yes, the identified portal alias is wrong. Find the correct alias for this portal
PortalAliasInfo pa = TabIndexController.GetPortalAliasByPortal(portalId, result.DomainName);
if (pa != null)
{
//note: sets portal id and portal alias
result.PortalAlias = pa;
}
}
}
}
}
else
{
//check for a portal alias if there's no portal Id in the query string
//check for absence of captcha value, because the captcha string re-uses the alias querystring value
if (queryStringCol["alias"] != null && queryStringCol["captcha"] == null)
{
string alias = queryStringCol["alias"];
PortalAliasInfo portalAlias = PortalAliasController.Instance.GetPortalAlias(alias);
if (portalAlias != null)
{
//ok the portal alias was found by the alias name
// check if the alias contains the domain name
if (alias.Contains(result.DomainName) == false)
{
// replaced to the domain defined in the alias
if (request != null)
{
//.........这里部分代码省略.........
示例12: ConfigurePortalAliasRedirect
/// <summary>
/// Configures the result object to set the correct Alias redirect
/// parameters and destination URL
/// </summary>
/// <param name="result"></param>
/// <param name="wrongAlias"></param>
/// <param name="rightAlias"></param>
/// <param name="ignoreCustomAliasTabs"></param>
/// <param name="redirectReason"></param>
/// <param name="internalAliases"></param>
/// <param name="settings"></param>
/// <returns></returns>
private static bool ConfigurePortalAliasRedirect(ref UrlAction result,
string wrongAlias,
string rightAlias,
bool ignoreCustomAliasTabs,
RedirectReason redirectReason,
List<InternalAlias> internalAliases,
FriendlyUrlSettings settings)
{
//wrong alias for the portal
//check to see if the wrong portal alias could be a custom alias for a tab
bool doRedirect;
if (ignoreCustomAliasTabs == false) //check out custom alias tabs collection
{
//if an alias is a custom tab alias for a specific tab, then don't redirect
if (CheckIfAliasIsCustomTabAlias(ref result, wrongAlias, settings))
doRedirect = false;
else
{
doRedirect = true;
}
}
else
{
doRedirect = true; //do redirect, ignore custom alias entries for tabs
}
//check to see if it is an internal alias. These are used to block redirects
//to allow for reverse proxy requests, which must change the rewritten alias
//while leaving the requested alias
bool internalAliasFound = false;
if (doRedirect && internalAliases != null && internalAliases.Count > 0)
{
if (internalAliases.Any(ia => String.Compare(ia.HttpAlias, wrongAlias, StringComparison.OrdinalIgnoreCase) == 0))
{
internalAliasFound = true;
doRedirect = false;
}
}
//if still need to do redirect, then set the settings that will cause the redirect (redirect not done here)
if (doRedirect)
{
result.Action = ActionType.Redirect301;
result.Reason = redirectReason;
string destUrl = result.OriginalPath.Replace(wrongAlias, rightAlias);
if (redirectReason == RedirectReason.Wrong_Portal_Alias_For_Culture ||
redirectReason == RedirectReason.Wrong_Portal_Alias_For_Culture_And_Browser)
{
destUrl = destUrl.Replace("/language/" + result.CultureCode, "");
}
destUrl = CheckForSiteRootRedirect(rightAlias, destUrl);
result.FinalUrl = destUrl;
}
else
{
//838 : don't overwrite the reason if already have checkfor301
// and don't do a check on the basis that an internal alias was found
if (result.Action != ActionType.CheckFor301 && internalAliasFound == false)
{
//set status to 'check for redirect'
result.Action = ActionType.CheckFor301;
result.Reason = RedirectReason.Custom_Tab_Alias;
}
}
return doRedirect;
}
示例13: CheckIfAliasIsCustomTabAlias
/// <summary>
/// Checks to see whether the specified alias is a customTabAlias
/// </summary>
/// <param name="result"></param>
/// <param name="httpAlias"></param>
/// <param name="settings"></param>
/// <returns></returns>
private static bool CheckIfAliasIsCustomTabAlias(ref UrlAction result, string httpAlias, FriendlyUrlSettings settings)
{
List<string> customAliasesForTabs = TabIndexController.GetCustomPortalAliases(settings);
bool isACustomTabAlias = false;
if (customAliasesForTabs != null && customAliasesForTabs.Count > 0)
{
//remove any customAliases that are also primary aliases.
foreach (var cpa in PortalAliasController.Instance.GetPortalAliasesByPortalId(result.PortalId))
{
if (cpa.IsPrimary == true && customAliasesForTabs.Contains(cpa.HTTPAlias))
{
customAliasesForTabs.Remove(cpa.HTTPAlias);
}
}
isACustomTabAlias = customAliasesForTabs.Contains(httpAlias.ToLower());
}
return isACustomTabAlias;
}
示例14: ProcessRequest
private void ProcessRequest(HttpContext context,
Uri requestUri,
bool useFriendlyUrls,
UrlAction result,
FriendlyUrlSettings settings,
bool allowSettingsChange,
Guid parentTraceId)
{
bool finished = false;
bool showDebug = false;
bool postRequest = false;
HttpRequest request = context.Request;
HttpResponse response = context.Response;
string requestType = request.RequestType;
NameValueCollection queryStringCol = request.QueryString;
try
{
string fullUrl, querystring;
//699: get the full url based on the request and the quersytring, rather than the requestUri.ToString()
//there is a difference in encoding, which can corrupt results when an encoded value is in the querystring
RewriteController.GetUrlWithQuerystring(request, requestUri, out fullUrl, out querystring);
showDebug = CheckForDebug(request, queryStringCol, settings.AllowDebugCode);
string ignoreRegex = settings.IgnoreRegex;
bool ignoreRequest = IgnoreRequest(result, fullUrl, ignoreRegex, request);
bool redirectAlias = false;
if (!ignoreRequest)
{
//set original path
context.Items["UrlRewrite:OriginalUrl"] = requestUri.AbsoluteUri;
//set the path of the result object, and determine if a redirect is allowed on this request
result.SetOriginalPath(requestUri.ToString(), settings);
//737 : set the mobile browser
result.SetBrowserType(request, response, settings);
//add to context
context.Items["UrlRewrite:BrowserType"] = result.BrowserType.ToString();
//839 : split out this check
result.SetRedirectAllowed(result.OriginalPath, settings);
//find the portal alias first
string wrongAlias;
bool isPrimaryAlias;
var requestedAlias = GetPortalAlias(settings, fullUrl, out redirectAlias, out isPrimaryAlias, out wrongAlias);
if (requestedAlias != null)
{
//827 : now get the correct settings for this portal (if not a test request)
//839 : separate out redirect check as well and move above first redirect test (ConfigurePortalAliasRedirect)
if (allowSettingsChange)
{
settings = new FriendlyUrlSettings(requestedAlias.PortalID);
result.SetRedirectAllowed(result.OriginalPath, settings);
}
result.PortalAlias = requestedAlias;
result.PrimaryAlias = requestedAlias;//this is the primary alias
result.PortalId = requestedAlias.PortalID;
result.CultureCode = requestedAlias.CultureCode;
//get the portal alias mapping for this portal
result.PortalAliasMapping = PortalSettings.GetPortalAliasMappingMode(requestedAlias.PortalID);
//if requested alias wasn't the primary, we have a replacement, redirects are allowed and the portal alias mapping mode is redirect
//then do a redirect based on the wrong portal
if ((redirectAlias && wrongAlias != null) && result.RedirectAllowed && result.PortalAliasMapping != PortalSettings.PortalAliasMapping.Redirect)
{
//this is the alias, we are going to enforce it as the primary alias
result.PortalAlias = requestedAlias;
result.PrimaryAlias = requestedAlias;
//going to redirect this alias because it is incorrect
//or do we just want to mark as 'check for 301??'
redirectAlias = ConfigurePortalAliasRedirect(ref result,
wrongAlias,
requestedAlias.HTTPAlias,
false,
settings.InternalAliasList,
settings);
}
else
{
//do not redirect the wrong alias, but set the primary alias value
if (wrongAlias != null)
{
//get the portal alias info for the requested alias (which is the wrong one)
//and set that as the alias, but also set the found alias as the primary
PortalAliasInfo wrongAliasInfo = PortalAliasController.Instance.GetPortalAlias(wrongAlias);
if (wrongAliasInfo != null)
{
result.PortalAlias = wrongAliasInfo;
result.PrimaryAlias = requestedAlias;
}
}
}
}
}
ignoreRegex = settings.IgnoreRegex;
//.........这里部分代码省略.........
示例15: RedirectPortalAlias
/// <summary>
/// Redirects an alias if that is allowed by the settings
/// </summary>
/// <param name="httpAlias"></param>
/// <param name="result"></param>
/// <param name="settings"></param>
/// <returns></returns>
private static bool RedirectPortalAlias(string httpAlias, ref UrlAction result, FriendlyUrlSettings settings)
{
bool redirected = false;
//redirect to primary alias
if (result.PortalAliasMapping == PortalSettings.PortalAliasMapping.Redirect && result.RedirectAllowed)
{
if (result.Reason == RedirectReason.Wrong_Portal_Alias_For_Browser_Type || result.Reason == RedirectReason.Wrong_Portal_Alias_For_Culture ||
result.Reason == RedirectReason.Wrong_Portal_Alias_For_Culture_And_Browser)
{
redirected = ConfigurePortalAliasRedirect(ref result, result.HttpAlias, httpAlias, false, result.Reason, settings.InternalAliasList, settings);
}
else
{
redirected = ConfigurePortalAliasRedirect(ref result, result.HttpAlias, httpAlias, false, settings.InternalAliasList, settings);
}
}
return redirected;
}