获取快捷方式文件夹的目标

发布于 2025-01-08 22:11:07 字数 43 浏览 0 评论 0原文

如何获取快捷方式文件夹的目录目标?我到处搜索,只找到快捷方式文件的目标。

How do you get the directory target of a shortcut folder? I've search everywhere and only finds target of shortcut file.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(7

╰◇生如夏花灿烂 2025-01-15 22:11:07

我认为您需要使用 COM 并添加对“Microsoft Shell Control And Automation”的引用,如此答案中所述。

下面是使用它的示例代码(来自现已不存在的 http://www.saunalahti.fi/janij/blog/2006-12.html#d6d9c7ee-82f9-4781-8594-152efecddae2):

namespace Shortcut
{
    using System;
    using System.Diagnostics;
    using System.IO;
    using Shell32;

    class Program
    {
        public static string GetShortcutTargetFile(string shortcutFilename)
        {
            string pathOnly = System.IO.Path.GetDirectoryName(shortcutFilename);
            string filenameOnly = System.IO.Path.GetFileName(shortcutFilename);

            Shell shell = new Shell();
            Folder folder = shell.NameSpace(pathOnly);
            FolderItem folderItem = folder.ParseName(filenameOnly);
            if (folderItem != null)
            {
                Shell32.ShellLinkObject link = (Shell32.ShellLinkObject)folderItem.GetLink;
                return link.Path;
            }

            return string.Empty;
        }

        static void Main(string[] args)
        {
            const string path = @"C:\link to foobar.lnk";
            Console.WriteLine(GetShortcutTargetFile(path));
        }
    }
}

I think you will need to use COM and add a reference to "Microsoft Shell Control And Automation", as described in this answer.

Here's example code to use it (from the now defunct http://www.saunalahti.fi/janij/blog/2006-12.html#d6d9c7ee-82f9-4781-8594-152efecddae2 ):

namespace Shortcut
{
    using System;
    using System.Diagnostics;
    using System.IO;
    using Shell32;

    class Program
    {
        public static string GetShortcutTargetFile(string shortcutFilename)
        {
            string pathOnly = System.IO.Path.GetDirectoryName(shortcutFilename);
            string filenameOnly = System.IO.Path.GetFileName(shortcutFilename);

            Shell shell = new Shell();
            Folder folder = shell.NameSpace(pathOnly);
            FolderItem folderItem = folder.ParseName(filenameOnly);
            if (folderItem != null)
            {
                Shell32.ShellLinkObject link = (Shell32.ShellLinkObject)folderItem.GetLink;
                return link.Path;
            }

            return string.Empty;
        }

        static void Main(string[] args)
        {
            const string path = @"C:\link to foobar.lnk";
            Console.WriteLine(GetShortcutTargetFile(path));
        }
    }
}
红焚 2025-01-15 22:11:07

在Windows 10中,需要像这样完成,首先将COM引用添加到“Microsoft Shell Control And Automation”

// new way for windows 10
string targetname;
string pathOnly = System.IO.Path.GetDirectoryName(LnkFileName);
string filenameOnly = System.IO.Path.GetFileName(LnkFileName);

Shell shell = new Shell();
Shell32.Folder folder = shell.NameSpace(pathOnly);
FolderItem folderItem = folder.ParseName(filenameOnly);
if (folderItem != null) {
  Shell32.ShellLinkObject link = (Shell32.ShellLinkObject)folderItem.GetLink;
  targetname = link.Target.Path;  // <-- main difference
  if (targetname.StartsWith("{")) { // it is prefixed with {54A35DE2-guid-for-program-files-x86-QZ32BP4}
    int endguid = targetname.IndexOf("}");
    if (endguid > 0) {
      targetname = "C:\\program files (x86)" + targetname.Substring(endguid + 1);
  }
}

In windows 10 it needs to be done like this, first add COM reference to "Microsoft Shell Control And Automation"

// new way for windows 10
string targetname;
string pathOnly = System.IO.Path.GetDirectoryName(LnkFileName);
string filenameOnly = System.IO.Path.GetFileName(LnkFileName);

Shell shell = new Shell();
Shell32.Folder folder = shell.NameSpace(pathOnly);
FolderItem folderItem = folder.ParseName(filenameOnly);
if (folderItem != null) {
  Shell32.ShellLinkObject link = (Shell32.ShellLinkObject)folderItem.GetLink;
  targetname = link.Target.Path;  // <-- main difference
  if (targetname.StartsWith("{")) { // it is prefixed with {54A35DE2-guid-for-program-files-x86-QZ32BP4}
    int endguid = targetname.IndexOf("}");
    if (endguid > 0) {
      targetname = "C:\\program files (x86)" + targetname.Substring(endguid + 1);
  }
}
离笑几人歌 2025-01-15 22:11:07

获取我使用的链接路径的更简单的方法是:

private static string LnkToFile(string fileLink)
{
    string link = File.ReadAllText(fileLink);
    int i1 = link.IndexOf("DATA\0");
    if (i1 < 0)
        return null;
    i1 += 5;
    int i2 = link.IndexOf("\0", i1);
    if (i2 < 0)
        return link.Substring(i1);
    else
        return link.Substring(i1, i2 - i1);
}

但是如果 lnk 文件格式发生更改,它当然会中断。

An even simpler way to get the linked path that I use is:

private static string LnkToFile(string fileLink)
{
    string link = File.ReadAllText(fileLink);
    int i1 = link.IndexOf("DATA\0");
    if (i1 < 0)
        return null;
    i1 += 5;
    int i2 = link.IndexOf("\0", i1);
    if (i2 < 0)
        return link.Substring(i1);
    else
        return link.Substring(i1, i2 - i1);
}

But it will of course break if the lnk-file format changes.

暗恋未遂 2025-01-15 22:11:07
public static string GetLnkTarget(string lnkPath)
{
    var shl = new Shell();
    var dir = shl.NameSpace(Path.GetDirectoryName(lnkPath));
    var itm = dir.Items().Item(Path.GetFileName(lnkPath));
    var lnk = (ShellLinkObject)itm.GetLink;

    if (!File.Exists(lnk.Path)){
       return lnk.Path.Replace("Program Files (x86)", "Program Files");
    }
    else{
       return lnk.Path;
    }
}
public static string GetLnkTarget(string lnkPath)
{
    var shl = new Shell();
    var dir = shl.NameSpace(Path.GetDirectoryName(lnkPath));
    var itm = dir.Items().Item(Path.GetFileName(lnkPath));
    var lnk = (ShellLinkObject)itm.GetLink;

    if (!File.Exists(lnk.Path)){
       return lnk.Path.Replace("Program Files (x86)", "Program Files");
    }
    else{
       return lnk.Path;
    }
}
逆光下的微笑 2025-01-15 22:11:07

我已经使用了它,始终基于内置的 Windows“Shell.Application”COM 对象,但使用纯后期绑定和反射来实现,因此不需要添加对现有项目的引用,并且没有任何依赖项。

    public static string GetLnkTarget(string lnkPath)
    {
        if (!System.IO.File.Exists(lnkPath))
            throw new FileNotFoundException();

        Type shlType;
        object shl = null;
        object dir = null;
        object items = null;
        object itm = null;
        object lnk = null;

        try
        {
            //var shl = new Shell();
            shlType = Type.GetTypeFromProgID("Shell.Application");
            shl = Activator.CreateInstance(shlType);

            string dirName = Path.GetDirectoryName(lnkPath);
            string lnkFile = Path.GetFileName(lnkPath);

            //var dir = shl.NameSpace(dirName);
            dir = shlType.InvokeMember("NameSpace", System.Reflection.BindingFlags.InvokeMethod, null, shl, new object[] { dirName });

            //var itm = dir.Items().Item(lnkFile);
            items = dir.GetType().InvokeMember("Items", System.Reflection.BindingFlags.InvokeMethod, null, dir, null);
            itm = items.GetType().InvokeMember("Item", System.Reflection.BindingFlags.InvokeMethod, null, items, new object[] { lnkFile });

            //var lnk = (ShellLinkObject)itm.GetLink;
            lnk = itm.GetType().InvokeMember("GetLink", System.Reflection.BindingFlags.GetProperty, null, itm, null);

            //return lnk.Path;
            object path = lnk.GetType().InvokeMember("Path", System.Reflection.BindingFlags.GetProperty, null, lnk, null);
            return (string)path;
        }
        catch (Exception ex)
        {
            throw ex;
        }
        finally
        {
            if (lnk != null) Marshal.ReleaseComObject(lnk);
            if (itm != null) Marshal.ReleaseComObject(itm);
            if (items != null) Marshal.ReleaseComObject(items);
            if (dir != null) Marshal.ReleaseComObject(dir);
            if (shl != null) Marshal.ReleaseComObject(shl);
        }
    }

I have used this, always based on builtin windows "Shell.Application" COM object, but implemented using pure late-binding and reflection, thus without any need to add a reference to the existing project, and without any dependencies.

    public static string GetLnkTarget(string lnkPath)
    {
        if (!System.IO.File.Exists(lnkPath))
            throw new FileNotFoundException();

        Type shlType;
        object shl = null;
        object dir = null;
        object items = null;
        object itm = null;
        object lnk = null;

        try
        {
            //var shl = new Shell();
            shlType = Type.GetTypeFromProgID("Shell.Application");
            shl = Activator.CreateInstance(shlType);

            string dirName = Path.GetDirectoryName(lnkPath);
            string lnkFile = Path.GetFileName(lnkPath);

            //var dir = shl.NameSpace(dirName);
            dir = shlType.InvokeMember("NameSpace", System.Reflection.BindingFlags.InvokeMethod, null, shl, new object[] { dirName });

            //var itm = dir.Items().Item(lnkFile);
            items = dir.GetType().InvokeMember("Items", System.Reflection.BindingFlags.InvokeMethod, null, dir, null);
            itm = items.GetType().InvokeMember("Item", System.Reflection.BindingFlags.InvokeMethod, null, items, new object[] { lnkFile });

            //var lnk = (ShellLinkObject)itm.GetLink;
            lnk = itm.GetType().InvokeMember("GetLink", System.Reflection.BindingFlags.GetProperty, null, itm, null);

            //return lnk.Path;
            object path = lnk.GetType().InvokeMember("Path", System.Reflection.BindingFlags.GetProperty, null, lnk, null);
            return (string)path;
        }
        catch (Exception ex)
        {
            throw ex;
        }
        finally
        {
            if (lnk != null) Marshal.ReleaseComObject(lnk);
            if (itm != null) Marshal.ReleaseComObject(itm);
            if (items != null) Marshal.ReleaseComObject(items);
            if (dir != null) Marshal.ReleaseComObject(dir);
            if (shl != null) Marshal.ReleaseComObject(shl);
        }
    }
故事↓在人 2025-01-15 22:11:07

如果您想找到桌面上有快捷方式的应用程序路径,我使用的一个简单方法如下:

Process.GetCurrentProcess().MainModule.FileName.Substring(0, Process.GetCurrentProcess().MainModule.FileName.LastIndexOf("\\")

此代码返回正在运行的任何 exe 路径,无论谁请求文件

if you want find your application path that has shortcut on desktop, an easy way that i use, is the following:

Process.GetCurrentProcess().MainModule.FileName.Substring(0, Process.GetCurrentProcess().MainModule.FileName.LastIndexOf("\\")

this code return any exe path that is running,Regardless that who requested file

許願樹丅啲祈禱 2025-01-15 22:11:07

所有文件快捷方式都有一个 .lnk 文件扩展名,您可以检查。例如,使用字符串,您可以使用 string.EndsWith(".lnk") 作为过滤器。

所有 URL 快捷方式都有一个 .url 文件扩展名,因此如果需要,您还需要考虑这些。

All file shortcuts have a .lnk file extension you can check for. Using a string for example, you could use string.EndsWith(".lnk") as a filter.

All URL shortcuts have a .url file extension, so you will need to account for those as well if needed.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文