Właśnie miałem potrzebę tej samej rzeczy OP pyta i po wyszukaniu w Google i przeczytaniu odpowiedzi, żaden z nich nie podał tego, co myślę, że OP i ja szukamy.
Problemem jest to, że można mapować udział sieciowy do Drive Y
, podczas gdy ktoś inny w organizacji może mieć ten sam udział sieciowy zmapowany jako Drive X
; dlatego wysłanie linku takiego jak Y:\mydirectory
nie może działać dla nikogo innego, oprócz mnie.
Jak wyjaśnia OP, Explorer pokazuje rzeczywistą ścieżkę w pasku eksploratora, ale nie można jej skopiować (pisanie jest żmudne i podatne na błędy, więc nie jest to opcja) nawet jeśli wybierzemy copy as path
z menu kontekstowego:
Tak więc rozwiązanie, które wymyśliłem (poprzez skopiowanie czyjegoś kodu) to mały program C#, który można wywołać z menu kontekstowego w eksploratorze i pozwoli na przetłumaczenie zmapowanej litery dysku na rzeczywisty UNC path
.
Oto kod:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Forms;
namespace Utils
{
//This is the only piece of code I wrote
class Program
{
[STAThread]
static void Main(string[] args)
{
//Takes the parameter from the command line. Since this will
//be called from the context menu, the context menu will pass it
//via %1 (see registry instructions below)
if (args.Length == 1)
{
Clipboard.SetText(Pathing.GetUNCPath(args[0]));
}
else
{
//This is so you can assign a shortcut to the program and be able to
//Call it pressing the shortcut you assign. The program will take
//whatever string is in the Clipboard and convert it to the UNC path
//For example, you can do "Copy as Path" and then press the shortcut you
//assigned to this program. You can then press ctrl-v and it will
//contain the UNC path
Clipboard.SetText(Pathing.GetUNCPath(Clipboard.GetText()));
}
}
}
}
A oto definicja klasy Pathing
(postaram się znaleźć faktyczne źródło, ponieważ nie pamiętam, gdzie je znalazłem):
public static class Pathing
{
[DllImport("mpr.dll", CharSet = CharSet.Unicode, SetLastError = true)]
public static extern int WNetGetConnection(
[MarshalAs(UnmanagedType.LPTStr)] string localName,
[MarshalAs(UnmanagedType.LPTStr)] StringBuilder remoteName,
ref int length);
/// <summary>
/// Given a path, returns the UNC path or the original. (No exceptions
/// are raised by this function directly). For example, "P:008-02-29"
/// might return: "\networkserver\Shares\Photos008-02-09"
/// </summary>
/// <param name="originalPath">The path to convert to a UNC Path</param>
/// <returns>A UNC path. If a network drive letter is specified, the
/// drive letter is converted to a UNC or network path. If the
/// originalPath cannot be converted, it is returned unchanged.</returns>
public static string GetUNCPath(string originalPath)
{
StringBuilder sb = new StringBuilder(512);
int size = sb.Capacity;
// look for the {LETTER}: combination ...
if (originalPath.Length > 2 && originalPath[1] == ':')
{
// don't use char.IsLetter here - as that can be misleading
// the only valid drive letters are a-z && A-Z.
char c = originalPath[0];
if ((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z'))
{
int error = WNetGetConnection(originalPath.Substring(0, 2),
sb, ref size);
if (error == 0)
{
DirectoryInfo dir = new DirectoryInfo(originalPath);
string path = Path.GetFullPath(originalPath)
.Substring(Path.GetPathRoot(originalPath).Length);
return Path.Combine(sb.ToString().TrimEnd(), path);
}
}
}
return originalPath;
}
}
Budujesz program i umieszczasz program wykonywalny gdzieś na swoim komputerze, na przykład w c:\Utils
Teraz dodajesz opcję menu kontekstowego w Explorerze, tak jak:
Regedit a następnie:
HKEY_CLASSES_ROOT\*\Directory\Shell
Right-click Shell --> New Key --> Name: "To UNC Path"
Right-click To UNC Path --> New Key --> Name: command
Right-click Default entry and select `Modify`
Value Data: c:\Utils\Utils.exe "%1"
Jesteś skończony. Teraz zobaczysz tę opcję, gdy klikniesz prawym przyciskiem myszy katalog z mapowanego dysku:
Uwaga
I can provide the executable so you don’t have to do the compilation yourself. Po prostu upuść mi notatkę tutaj.